JOIN,INSERT句法.docx

上传人:人*** 文档编号:559625473 上传时间:2023-10-21 格式:DOCX 页数:6 大小:22.81KB
返回 下载 相关 举报
JOIN,INSERT句法.docx_第1页
第1页 / 共6页
JOIN,INSERT句法.docx_第2页
第2页 / 共6页
JOIN,INSERT句法.docx_第3页
第3页 / 共6页
JOIN,INSERT句法.docx_第4页
第4页 / 共6页
JOIN,INSERT句法.docx_第5页
第5页 / 共6页
点击查看更多>>
资源描述

《JOIN,INSERT句法.docx》由会员分享,可在线阅读,更多相关《JOIN,INSERT句法.docx(6页珍藏版)》请在金锄头文库上搜索。

1、JOIN句法MySQL支持下列用于SELECT语句的JOIN句法: table_reference, table_referencetable_reference CROSS JOIN table_referencetable_reference INNER JOIN table_referencetable_reference STRAIGHT_JOIN table_referencetable_reference LEFT OUTER JOIN table_reference ON conditional_exprtable_reference LEFT OUTER JOIN table_

2、reference USING (column_list)table_reference NATURAL LEFT OUTER JOIN table_reference oj table_reference LEFT OUTER JOIN table_reference ON conditional_expr 上述最后的LEFT OUTER JOIN的句法只是为了与ODBC兼容而存在的。 一个表可以是使用aliasedtbl_name AS alias_name或tbl_name alias_name的起的别名。 mysql select t1.name, t2.salary from emp

3、loyee AS t1, info AS t2 where t1.name = t2.name; INNER JOIN和,(逗号)在语义上是等价的,都是进行一个在使用的表之间的全联结。通常,你指定表应该如何用WHERE条件联结起来。 ON条件是可以用在一个WHERE子句形式的任何条件。 如果在一个LEFT JOIN中没有右表的匹配记录,一个所有列设置为NULL的行被用于右表。你可以使用这个事实指出表中在另一个表中没有对应记录的记录: mysql select table1.* from table1 LEFT JOIN table2 ON table1.id=table2.id where t

4、able2.id is NULL;这个例子找出在table1中所有的行,其id值在table2中不存在(即,所有table1中的在table2中没有对应行的行)。当然这假定table2.id被声明为NOT NULL。 USING (column_list)子句命名一系列必须存在于两个表中的列。 例如一个USING子句: A LEFT JOIN B USING (C1,C2,C3,.)被定义成在语义上等同一个这样的ON表达式: A.C1=B.C1 AND A.C2=B.C2 AND A.C3=B.C3,. 2个表的NATURAL LEFT JOIN被定义为在语义上等同于一个有USING子句命名在

5、两表中存在的所有列的一个LEFT JOIN。 STRAIGHT_JOIN等同于JOIN,除了左表在右表之前被读入,这能用于这些情况,联结优化器将表的顺序放错了。 一些例子: mysql select * from table1,table2 where table1.id=table2.id;mysql select * from table1 LEFT JOIN table2 ON table1.id=table2.id;mysql select * from table1 LEFT JOIN table2 USING (id);mysql select * from table1 LEFT

6、 JOIN table2 ON table1.id=table2.id LEFT JOIN table3 ON table2.id=table3.id;见10.5.4 MySQL怎样优化LEFT JOIN。 INSERT句法 INSERT LOW_PRIORITY | DELAYED IGNORE INTO tbl_name (col_name,.) VALUES (expression,.),(.),.或 INSERT LOW_PRIORITY | DELAYED IGNORE INTO tbl_name (col_name,.) SELECT .或 INSERT LOW_PRIORITY

7、| DELAYED IGNORE INTO tbl_name SET col_name=expression, col_name=expression, .INSERT把新行插入到一个存在的表中,INSERT . VALUES形式的语句基于明确指定的值插入行,INSERT . SELECT形式插入从其他表选择的行,有多个值表的INSERT . VALUES的形式在MySQL 3.22.5或以后版本中支持,col_name=expression语法在MySQL 3.22.10或以后版本中支持。 tbl_name是行应该被插入其中的表。列名表或SET子句指出语句为那一列指定值。 如果你为INSER

8、T . VALUES或INSERT . SELECT不指定列表,所有列的值必须在VALUES()表或由SELECT提供。如果你不知道表中列的顺序,使用DESCRIBE tbl_name来找出。 任何没有明确地给出值的列被设置为它的缺省值。例如,如果你指定一个列表并没命名表中所有列,未命名的列被设置为它们的缺省值。缺省值赋值在7.7 CREATE TABLE句法中描述。 一个expression可以引用在一个值表先前设置的任何列。例如,你能这样: mysql INSERT INTO tbl_name (col1,col2) VALUES(15,col1*2);但不能这样: mysql INSER

9、T INTO tbl_name (col1,col2) VALUES(col2*2,15); 如果你指定关键词LOW_PRIORITY,INSERT的执行被推迟到没有其他客户正在读取表。在这种情况下,客户必须等到插入语句完成后,如果表频繁使用,它可能花很长时间。这与INSERT DELAYED让客马上继续正好相反。 如果你在一个有许多值行的INSERT中指定关键词IGNORE,表中任何复制一个现有PRIMARY或UNIQUE键的行被忽略并且不被插入。如果你不指定IGNORE,插入如果有任何复制现有关键值的行被放弃。你可用C API函数mysql_info()检查多少行被插入到表中。 如果MyS

10、QL用DONT_USE_DEFAULT_FIELDS选项配置,INSERT语句产生一个错误,除非你明确对需要一个非NULL值的所有列指定值。见4.7.3 典型configure选项。 INSERT INTO . SELECT语句满足下列条件: o 查询不能包含一个ORDER BY子句。 o INSERT语句的目的表不能出现在SELECT查询部分的FROM子句,因为这在ANSI SQL中被禁止让从你正在插入的表中SELECT。(问题是SELECT将可能发现在同一个运行期间内先前被插入的记录。当使用子选择子句时,情况能很容易混淆) o AUTO_INCREMENT列象往常一样工作。 如果你使用IN

11、SERT . SELECT或INSERT . VALUES语句有多个值列表,你可以使用C API函数mysql_info()得到查询的信息。信息字符串的格式如下: Records: 100 Duplicates: 0 Warnings: 0 Duplicates指出不能被插入的行的数量,因为他们与现有的唯一的索引值重复。Warnings指出在出现某些问题时尝试插入列值的次数。在下列任何条件下都可能发生错误: 插入NULL到被声明了NOT NULL的列,列被设置为它的缺省值。 将超出列范围的值设置给一个数字列,值被剪切为范围内适当的端点值。 将数字列设成例如10.34 a的值,拖尾的垃圾被剥去并

12、仍然是数字部分被插入。如果值根本不是一个数字,列被设置到0。 把一个字符串插入到超过列的最大长度的一个CHAR、VARCHAR、TEXT或BLOB列中。值被截断为列的最大长度。 把一个对列类型不合法的值插入到一个日期或时间列。列被设置为该列类型适当的“零”值。 对于INSERT语句的DELAYED选项是MySQL专属的选项-如果你客户有不能等到INSERT完成,它是很有用的。当你为日记登录使用MySQL时,而且你也周期性地运行花很长时间完成的SELECT语句,这是一个常见的问题。DELAYED在面MySQL 3.22.15中被引入,它是MySQL对 ANSI SQL92 的一个扩展。 当你使用

13、INSERT DELAYED时,客户将马上准备好,并且当表不被任何其他的线程使用时,行将被插入。另一个使用INSERT DELAYED的主要好处是从很多客户插入被捆绑在一起并且写进一个块。这比做很多单独的插入要来的快。 注意,当前排队的行只是存储在内存中,直到他们被插入到表中。这意味着,如果你硬要杀死mysqld(kill -9)或如果mysqld出人意料地死掉,没被写进磁盘的任何排队的行被丢失! 下列详细描述当你为INSERT或REPLACE使用DELAYED选项时,发生什么。在这个描述中,“线程”是收到一个INSERT DELAYED命令的线程并且“处理器”是处理所有对于一个特定表的INS

14、ERT DELAYED语句。 当一个线程对一个表执行一个DELAYED语句时,如果不存在这样的处理程序,一个处理器线程被创建以处理对于该表的所有DELAYED语句。 线程检查处理程序是否已经获得了一个DELAYED锁;如果没有,它告诉处理程序去获得。即使其他的线程有在表上的一个READ或WRITE锁,也能获得DELAYED锁。然而,处理程序将等待所有ALTER TABLE锁或FLUSH TABLES以保证表结构是最新的。 线程执行INSERT语句,但不是将行写入表,它把最后一行的副本放进被处理器线程管理的一个队列。任何语法错误都能被线程发觉并报告给客户程序。 顾客不能报告结果行的重复次数或AU

15、TO_INCREMENT值;它不能从服务器获得它们,因为INSERT在插入操作完成前返回。如果你使用C API,同样原因,mysql_info()函数不返回任何有意义的东西。 当行被插入到表中时,更新日志有处理器线程更新。在多行插入的情况下,当第一行被插入时,更新日志被更新。 在每写入delayed_insert_limit行后,处理器检查是否任何SELECT语句仍然是未完成,如果这样,在继续之前允许执行这些语句。 当处理器在它的队列中没有更多行时,表被解锁。如果在delayed_insert_timeout秒内没有收到新的INSERT DELAYED命令,处理器终止。 如果已经有多于delayed_queue_size行在一个特定的处理器队列中未解决,线程等待直到队列有空间。这有助于保证mysqld服务器对延迟的内存队列不使用所有内存。 处理器线程将在Command列的MySQL进程表中显示delayed_i

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 社会民生

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号