知识大全 MySQL中文参考手册--- MySQL与标准的兼容性

Posted 语句

篇首语:你可以忘掉失败,但不能忘掉教训;你可以忘掉昨天,但不能忘记历史。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 MySQL中文参考手册--- MySQL与标准的兼容性相关的知识,希望对你有一定的参考价值。

MySQL中文参考手册--- MySQL与标准的兼容性  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

  MySQL包含了一些可能在其他SQL数据库找不到的扩充 要注意如果你使用他们 你的代码将不与其他SQL服务器兼容 在一些情况下 你可以编写包括MySQL扩展的代码 但是仍然是可移植的 通过使用/*! */形式的注释 在这种情况下 MySQL将进行词法分析并且执行在注释内的代码 好像它是任何其它MySQL语句 但是其他SQL服务器将忽略扩展 例如     SELECT /*! STRAIGHT_JOIN */ col_name FROM table table WHERE   如果你在 ! 后增加一个版本数字 该语法将仅在MySQL版本是等于或比使用的版本数字新时才执行     CREATE /*! TEMPORARY */ TABLE (a int);    上面的意思是如果你有 或更新 那么MySQL将使用TEMPORARY关键词      MySQL扩展被列在下面   字段类型MEDIUMINT SET ENUM和不同的BLOB和TEXT类型   字段属性AUTO_INCREMENT BINARY UNSIGNED和ZEROFILL   缺省地 所有的字符串比较是忽略大小写的 由当前的字符集决定了(缺省为ISO Latin )排序顺序 如果你不喜欢这样 你应该用BINARY属性或使用BINARY强制符声明列 它导致根据MySQL服务器主机的ASCII顺序进行排序   MySQL将每个数据库映射一个MySQL数据目录下面的目录 将数据库表映射到数据库目录下的数据库文件名 这有 个含意   在区分大小写文件名的操作系统(象大多数 Unix 系统一样)上的MySQL中数据库名字和表名是区分大小写的 如果你有困难记得表名 接受一个一致的约定 例如总是用小写名字创建数据库和表     数据库 表 索引 列或别名可以以数字开始(但是不能仅由数字组成)   你可以使用标准的系统命令备份 重命名 移动 删除和拷贝表 例如 重命名一个表 重命名 MYD MYI 和 frm 文件为相应的表   在SQL语句中 你可以用db_name tbl_name语法访问不同数据库中的表 一些SQL服务器提供同样的功能但是称它们为这User space(用户空间) MySQL不支持类似在create table ralph my_table IN my_tablespace中的表空间   LIKE在数字列上被允许     在一SELECT语句里面使用INTO OUTFILE和STRAIGHT_JOIN 见 SELECT句法   在一个SELECT语句中SQL_SMALL_RESULT选项   EXPLAIN SELECT得到如何联结表的描述     在一个CREATE TABLE语句里面使用索引 在字段前缀上的索引和使用INDEX或KEY 见 CREATE TABLE 句法   CREATE TABLE使用TEMPORARY或IF NOT EXISTS   使用COUNT(DISTINCT list) 这里 list 超过一个元素   在一个ALTER TABLE语句里面使用CHANGE col_name DROP col_name或DROP INDEX 见 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语句的LOW_PRIORITY子句   使用LOAD DATA INFILE 在多数情况下 这句法与Oracle的LOAD DATA INFILE兼容 见 LOAD DATA INFILE 句法   OPTIMIZE TABLE语句   SHOW语句 见 SHOW句法(得到表 列等的信息)   字符串可以被 或 包围 而不只是   使用 \\ 转义字符   SET OPTION语句 见 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 见 CREATE DATABASE句法   %操作符是MOD()一个同义词 即 N % M等价于MOD(N M) %支持C程序员并与PostgreSQL兼容   = <> <=,<, >=,> <<, >> <=> AND OR或LIKE操作符可以放在SELECT语句的FROM左边用于比较列 例如   mysql> SELECT col = AND col = FROM tbl_name;    LAST_INSERT_ID()函数 见 mysql_insert_id()   扩展的正则表达式操作符REGEXP和NOT REGEXP   CONCAT()或CHAR()有一个参数或超过 个参数 (在MySQL中 这些函数可取任何数量的参数 )    BIT_COUNT() CASE ELT() FROM_DAYS() FORMAT() IF() PASSWORD() ENCRYPT() md () ENCODE() DECODE() PERIOD_ADD() PERIOD_DIFF() TO_DAYS() 或WEEKDAY()函数     使用TRIM()整修子串 ANSI SQL 只支持单个字符的删除   GROUP BY函数STD() BIT_OR()和BIT_AND()   使用REPLACE而不是DELETE+INSERT 见 REPLACE句法   FLUSH flush_option语句     在一个语句用:=设置变量的可能性   SELECT @a:=SUM(total) @b=COUNT(*) @a/@b AS avg FROM test_table;  SELECT @t :=(@t := )+@t := @t @t @t ;     以ANSI模式运行MySQL  如果你用 ansi选项启动mysqld MySQL的下列行为改变     ||是字符串并置而不是OR   可在一个函数名字之间与 ( 有任何数量的空格 这也使所有的功能名字成为保留词    将是一个标识符引号字符(象MySQL `引号字符一样)而不是一个字符串引号字符   REAL将是FLOAT一个同义词 不是DOUBLE一个同义词    MySQL相比ANSI SQL 的差别  我们尝试使得MySQL遵照ANSI SQL标准和ODBC SQL标准 但是在一些情况下 MySQL做一些不同的事情      只是一个注释 如果后面跟一个白空字符 ` 作为一个注释的开始   对于VARCHAR列 当值被存储时 拖后的空格被删除 见E MySQL已知的错误和设计缺限   在一些情况下 CHAR列偷偷地被改变为VARCHAR列 平静的列指定变化   当你删除一个表时 对表的权限不自动地废除 你必须明确地发出一个REVOKE来废除对一个表的权限 见 GRANT和REVOKE句法    MySQL缺乏的功能  下列功能在当前的MySQL版本是没有的 对于一张优先级表指出何时新扩展可以加入MySQL 你应该咨询在线MySQL TODO 表 这是本手册最新的TODO表版本 见F 我们想要在未来加入到MySQL的事情列表(TODO)        子选择  在MySQL中下列语句还不能工作     SELECT * FROM table WHERE id IN (SELECT id FROM table );  SELECT * FROM table WHERE id NOT IN (SELECT id FROM table );    然而 在很多情况下 你可以重写查询 而不用子选择     SELECT table * FROM table table WHERE table id=table id;  SELECT table * FROM table LEFT JOIN table ON table id=table id where table id IS NULL    对于更复杂的子查询 通常你可以创建临时的表保存子查询 然而在一些情况下 这种选择将行不通 最经常遇到的情形是DELETE语句 对于它标准SQL不支持联结(join)(除了在子选择) 对于这种情况 有 个可用选择 直到子选择被MySQL支持     第一个选择是使用一种过程化的程序语言(例如Perl或PHP)来提交一个SELECT查询获得要被删除记录主键 并然后使用这些值构造DELETE语句(DELETE FROM WHERE IN (key key ))     第二个选择是使用交互式SQL自动构造一套DELETE语句 使用MySQL扩展CONCAT()(代替标准||操作符) 例如     SELECT CONCAT( DELETE FROM tab WHERE pkid = tab pkid ; )  FROM tab tab   WHERE l = l ;    你可以把这个查询放在一个脚本文件并且从它重定向输入到mysql命令行解释器 将其输出作为管道返回给解释器的第 个实例     prompt> mysql skip column names mydb < myscript sql | mysql mydb    MySQL仅支持INSERT SELECT 和REPLACE SELECT 独立的子选择将可能在 得到 然而 在其他环境下 你现在可以使用函数IN()       SELECT INTO TABLE  MySQL还不支持Oracle SQL的扩展 SELECT INTO TABLE 相反MySQL支持ANSI SQL句法INSERT INTO SELECT 基本上他们是一样的     另外 你可使用SELECT INTO OUTFILE 或CREATE TABLE SELECT解决你的问题      事务处理  不支持事务处理 MySQL将在短时间内支持原子(atomic)操作 它象没有回卷的事务 用原子操作 你能执行一组INSERT/SELECT/whatever 命令并且保证没有其他线程介入 在本文中 你通常不会需要回卷 目前 你可通过使用LOCK TABLES和UNLOCK TABLES命令阻止其他线程的干扰 见 LOCK TABLES/UNLOCK TABLES句法      存储过程和触发器  一个存储过程是能在服务器中编译并存储的一套SQL命令 一旦这样做了 顾客不需要一直重新发出全部查询 而可以参考存储过程 因为查询仅需一次词法分析并且较少的信息需要在服务器和客户之间传送 因此这提供了更好的性能 你与可以通过拥有在服务器中的函数库提升概念上的层次 cha138/Article/program/MySQL/201311/29423

相关参考

知识大全 MySQL中文参考手册---MySQL 文件系统

MySQL中文参考手册---MySQL文件系统  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  这

知识大全 MySQL中文参考手册-- 输入查询

MySQL中文参考手册--输入查询  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  确保你连接上了

知识大全 MySQL中文参考手册-- 常用查询的例子

MySQL中文参考手册--常用查询的例子  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  下面是一

知识大全 MySQL中文参考手册-- 创造并使用一个数据库

MySQL中文参考手册--创造并使用一个数据库  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  既

知识大全 MYSQL 双机热备配置手册

MYSQL双机热备配置手册  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!MYSQL双机热备配置手册

知识大全 让MYSQL彻底支持中文

让MYSQL彻底支持中文  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  提要系统自带的mysql

知识大全 搞定MySQL数据库中文模糊检索问题

搞定MySQL数据库中文模糊检索问题  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  在MySQL

知识大全 Mysql数据库错误代码中文详细说明

Mysql数据库错误代码中文详细说明  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  在mysql

知识大全 linux系统下mysql中文乱码解决

  改默认编码  /etc/initd/mysqlstart(stop)为启动和停止服务器  /etc/mysql/主要配置文件所在位置f  /var/lib/mysql/放置的是数据库表文件夹这里的

知识大全 解析Hibernate + MySQL中文乱码问题

解析Hibernate+MySQL中文乱码问题  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  如