MySQL使用的大多数C API函数之间拼写差别。例如,它将msqlConnect()实例改变为mysql_connect()。变换一个客户程序从mSQL到MySQL通常花几分钟时间。
21.1.1 怎样将mSQL的工具转换到MySQL
根据我们的经验,转换诸如使用mSQL C API的msql-tcl和msqljava工具将只花不大一小时时间,使得他们用MySQL C API工作。
转换过程是:
在源代码上运行外壳脚本msql2mysql。这需要replace程序,它与MySQL一起散发。
编译。
修正所有编译器错误。
mSQL C API与MySQL C API 之间差别是:
MySQL使用一个MYSQL结构作为一种连接类型(mSQL使用一个int)。
mysql_connect()取一个指向一个MYSQL结构的指针作为一个参数。很容易定义全局性定义一个或使用malloc()获得一个。mysql_connect()也取两个参数指定用户和口令。你可以为了缺省使用将这些设置为NULL,NULL。
mysql_error()取MYSQL结构作为一个参数。如果你正在移植老的代码,只是把参数加到你的老的msql_error()编码中。
MySQL对所有错误返回一个错误号和一条文本错误消息。mSQL仅返回一条文字错误消息。
存在某些不兼容性,因为MySQL支持从同一个进程的到服务器多个连接。
mSQL和MySQL的客户机/服务器通讯协议有何不同
有足够的差别使得不可能(或至少不容易)支持两者。
它MySQL协议不同于mSQL协议的最重要的方面列在下面:
一个消息缓冲区可以包含很多结果行。
如果查询或结果比当前缓冲区大,消息缓冲区动态地被扩大,直到一个可配置的服务器和客户上限。
所有的包被编号以捕捉重复或丢失的包。
所有的列值以ASCII码发送。列和行的长度以紧凑的二进制编码(1、2或3个字节)发送。
MySQL能在未缓冲得结果中读取(不必在客户端存储完整的集合)。
如果一个单独写/读花了超过30秒时间,服务器关闭连接。
如果一个连接空闲8个小时,服务器关闭连接。
mSQL 2.0的SQL句法与MySQL有何不同
列类型
MySQL
有下列额外的类型(比较其他的;见7.7 CREATE TABLE句法): 、
对于一个字符串集中之一的ENUM类型。
对于一个字符串集中多个的SET类型。
对于64位整数的BIGINT类型。
MySQL也支持下列额外的类型属性:
UNSIGNED选项。
对于整数列的ZEROFILL选项。
对于是一个PRIMARY KEY的整数列的AUTO_INCREMENT选项。见20.4.29 mysql_insert_id()。
对所有列的DEFAULT值。
mSQL2
mSQL列类型对应于MySQL类型显示在下面:mSQL类型 相应的MySQL类型
CHAR(len) CHAR(len)
TEXT(len) TEXT(len),len是最大长度。并且LIKE可运用。
INT INT,有很多的选项!
REAL REAL,或FLOAT。有4和8字节版本。
UINT INT UNSIGNED
DATE DATE,使用 ANSI SQL 格式而非mSQL自己的。
TIME TIME
MONEY DECIMAL(12,2),有2个小数位的定点值。
索引创建
MySQL
索引可以在表创建时用CREATE TABLE语句指定。
mSQL
在表被创建了以后,索引必须被创建,用单独的CREATE INDEX语句。
把一个唯一标识符插入到一张表中
MySQL 使用AUTO_INCREMENT作为列类型修饰符。见20.4.29 mysql_insert_id()。
mSQL
在一张表上创建一个SEQUENCE并且选择_seq列。
为行获得一个唯一标识符
MySQL 向表中增加一个PRIMARY KEY或UNIQUE键。
mSQL 使用_rowid列。注意_rowid可以将来改变,取决于很多因素。
得到列最后被修改的时间
MySQL 在表中增加一个TIMESTAMP列。如果你不给出列值或如果你给它一个NULL值,该列自动为INSERT或UPDATE语句设置为当前的日期和时间。
mSQL 使用_timestamp列。
NULL值的比较
MySQL MySQL遵从ANSI SQL且与NULL的比较总是NULL。
mSQL 在mSQL中,NULL = NULL是TRUE(真)。当从mSQL到MySQL移植老的代码时,你必须将=NULL改委IS NULL,并将<>NULL改为IS NOT NULL。
字符串的比较
MySQL
通常,字符串比较以大小写无关方式按当前字符集(缺省为ISO-8859-1 Latin1)决定的排序次序实施。如果你不喜欢这样,声明你的列有BINARY属性,它使得比较根据用在MySQL服务器主机上的ASCII顺序进行。
mSQL
所有的字符串比较以大小写敏感的方式以ASCII顺序排序来进行。
大小写不敏感的搜索
MySQL
LIKE是一个大小写不敏感或大小写敏感的运算符,这取决于涉及的列。如果LIKE参数不以一个通配符字符开始,如有可能,MySQL则使用索引。
mSQL
使用CLIKE。
尾部空格的处理
MySQL
剥去CHAR和VARCHAR列尾部的空格。如果不希望这种行为,使用一个TEXT行列。
mSQL
保留尾部的空格。
WHERE子句
MySQL
MySQL正确地优先化任何东西(AND在OR前计算)。要想在MySQL里得到mSQL的行为,使用括号(如下所示)。
mSQL
从左到右计算任何东西。这意味着超过3个参数的一些逻辑运算不能以任何方式表示,它也意味着当你升级到MySQL时,你必须改变一些查询。你通过增加括号很容易做到这点。假定你有下列mSQL查询:
mysql> SELECT * FROM table WHERE a=1 AND b=2 OR a=3 AND b=4;
为了使MySQL像mSQL那样计算它,你必须增加括号:
mysql> SELECT * FROM table WHERE (a=1 AND (b=2 OR (a=3 AND (b=4))));
存取控制
MySQL
有表来存储对每个用户、主机和
数据库的授权(许可)选项。见6.6 权限系统如何工作。
mSQL
有一个文件“mSQL.acl”,在哪里你能为用户授权读/写权限。
怎样对比MySQL与PostgreSQL
PostgreSQL有一些更高级的功能如定义用户类型、触发