有关MySQL数据库与标准的兼容性问题 电脑资料
MySQL包含了一些可能在其他SQL数据库不到的扩充,
如果你在'!'后增加一个版本数字,该语法将仅在MySQL版本是等于或比使用的版本数字新时才执行:
上面的意思是如果你有3.23.02或更新,那么MySQL将使用TEMPORARY关键词。
MySQL扩展被列在下面:
字段类型MEDIUMINT、SET、ENUM和不同的BLOB和TEXT类型。
字段属性AUTOINCREMENT、BINARY、UNSIGNED和ZEROFILL。
缺省地,所有的字符串比拟是忽略大小写的,由当前的字符集决定了(缺省为ISO-8859-1 Latin1)排序顺序。如果你不喜欢这样,你应该用BINARY属性或使用BINARY强制符声明列,它导致根据MySQL效劳器主机的ASCII顺序进行排序。
MySQL将每个数据库映射一个MySQL数据目录下面的目录,将数据库表映射到数据库目录下的数据库文件名。这有2个含意:
在区分大小写文件名的操作系统(象大多数 Unix 系统一样)上的MySQL中数据库名字和表名是区分大小写的。如果你有困难记得表名,接受一个一致的约定,例如总是用小写名字创立数据库和表。
数据库、表、索引、列或别名可以以数字开始(但是不能仅由数字组成)。
你可以使用标准的系统命令备份、重命名、移动、删除和拷贝表。例如,重命名一个表,重命名“.MYD”、“.MYI”和“.frm”文件为相应的表。
在SQL语句中,你可以用dbname.tblname语法访问不同数据库中的表。一些SQL效劳器提供同样的功能但是称它们为这User space(用户空间)。MySQL不支持类似在create IN mytablespace中的表空间。
LIKE在数字列上被允许。
在一SELECT语句里面使用INTO OUTFILE和STRAIGHTJOIN。见7.12 SELECT句法.
在一个SELECT语句中SQLSMALLRESULT选项。
EXPLAIN SELECT得到如何联结表的描述。
在一个CREATE TABLE语句里面使用索引、在字段前缀上的索引和使用INDEX或KEY。见7.7 CREATE TABLE 句法。
CREATE TABLE使用TEMPORARY或IF NOT EXISTS。
使用COUNT(DISTINCT list),这里“list”超过一个元素。
在一个ALTER TABLE语句里面使用CHANGE colname、DROP colname或DROP INDEX。见7.8 ALTER TABLE句法。
在一个ALTER TABLE里面语句使用IGNORE。
在一个ALTER TABLE语句中使用多重ADD、ALTER、DROP或CHANGE子句。
使用带关键词IF EXISTS的DROP TABLE。
你能用单个DROP TABLE语句抛弃多个表。
DELETE语句的LIMIT子句。
INSERT和REPLACE语句的DELAYED子句。
INSERT, REPLACE, DELETE和UPDATE语句的LOWPRIORITY子句。
使用LOAD DATA INFILE。在多数情况下,这句法与Oracle的LOAD DATA INFILE兼容。见7.16 LOAD DATA INFILE 句法。
OPTIMIZE TABLE语句。。
SHOW语句。见7.21 SHOW句法(得到表、列等的信息)。
字符串可以被“"”或“'”包围,而不只是“'”。
使用“”转义字符。
mysql下载odbc失败SET OPTION语句。见7.25 SET OPTION句法。
你不需要命名所有在GROUP BY局部的被选择的列。这为一些很特定的情况给出更好的性能,而不是一般的查询。
为了方便于SQL环境其他为用户,MySQL对许多函数支持别名。例如,所有的字符串功能都支持ANSI SQL句法和 ODBC句法。
MySQL理解||和&&意味着逻辑的OR和AND,就像在C程序语言中。在MySQL中,||和OR是同义词,&&和AND是同义词。正因为这个好的句法,MySQL对字符串并置的不支持ANSI SQL ||操作符;相反使用CONCAT(),因为CONCAT()接受任何数量的参数,很容易把||操作符使用变换到MySQL。
CREATE DATABASE或DROP DATABASE。见7.5 CREATE DATABASE句法。
%操作符是MOD()一个同义词,即,N % M等价于MOD(N,M)。%支持C程序员并与PostgreSQL兼容。
=, <>, <=,<, >=,>, <<, >>, <=>, AND, OR或LIKE操作符可以放在SELECT语句的FROM左边用于比拟列。例如:
扩展的正那么表达式操作符REGEXP和NOT REGEXP。
CONCAT()或CHAR()有一个参数或超过2个参数。(在MySQL中,这些函数可取任何数量的参数。)
BITCOUNT(), CASE, ELT(), FROMDAYS(), FORMAT(), IF(), PASSWORD(), ENCRYPT(), md5(), ENCODE(), DECODE(), PERIODADD(), PERIODDIFF(), TODAYS(),或WEEKDAY()函数。
使用TRIM()整修子串。ANSI SQL 只支持单个字符的删除。
GROUP BY函数STD(), BITOR()和BITAND()。
使用REPLACE而不是DELETE+INSERT。见7.15 REPLACE句法。
FLUSH flushoption语句。
在一个语句用:=设置变量的可能性:
以ANSI模式运行MySQL
如果你用--ansi选项启动mysqld,MySQL的以下行为改变。
||是字符串并置而不是OR。
可在一个函数名字之间与“(”有任何数量的空格。这也使所有的功能名字成为保存词。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论