联结。如果你改变一个SELECT中的表的顺序,mSQL可能变得异常地慢。在基准套件中,比MySQL要慢超过15000倍的时间。这是由于mSQL缺乏一个联结优化器以便以最佳的顺序排定表。然而,如果你把表按完全正确的顺序放在mSQL2中并且WHERE是很简单的并使用索引列,联结将相对快些!见10.8 使用你自己的基准。 ORDER BY和GROUP BY。 DISTINCT。 使用TEXT或BLOB列。
SQL功能 GROUP BY和HAVING。mSQL根本不支持GROUP BY。MySQL支持一个有两个HAVING和下列函数: COUNT()、AVG()、MIN()、MAX()、SUM()和STD()的完整的GROUP BY。如果SELECT从一张表中检索,没有其他列被检索并且没有WHERE子句,COUNT(*)被优化以很快地返回。 MIN()和MAX()可以取字符串参数。 带计算的INSERT和UPDATE。MySQL能在一个INSERT或UPDATE中做计算。例如: mysql> UPDATE SET x=x*10+y WHERE x<20;
实用程序 mSQL和MySQL都有许多有趣的第三方工具。因为向上移植(从mSQL到MySQL)是很容易的,几乎所有mSQL可用的有趣的应用程序也可被MySQL使用。MySQL带有一个简单的msql2mysql程序修正在mSQL和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 之间差别是:
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列。 为行获得一个唯一标识符