Mysql学习Mysql INSERT INTO语句用法详解
《Mysql学习Mysql INSERT INTO语句用法详解》要点: mysql数据库中,INSERT INTO语句的结构: [INTO] tbl_name [(col_name,...)] VALUES (expression,...),(...),... INSERT INTO SELECT语句: [INTO] tbl_name [(col_name,...)] SELECT ... INSERT INTO语句: [INTO] tbl_name SET col_name=expression,col_name=expression,... INSERT把新行插入到一个存在的表中,INSERTINTO... VALUES形式的语句基于明确指定的值插入行,INSERT INTO SELECT形式插入从其他表选择的行,有多个值表的INSERT INTO... VALUES的形式在MySQL 3.22.5或以后版本中支持,col_name=expression语法在MySQL 3.22.10或以后版本中支持.MYSQL数据库 tbl_name是行应该被插入其中的表.列名表或SET子句指出语句为那一列指定值.MYSQL数据库 如果为INSERT ... VALUES或INSERT ... SELECT不指定列表,所有列的值必须在VALUES()表或由SELECT提供.如果不知道表中列的顺序,使用DESCRIBE tbl_name来找出. 例如,如果指定一个列表并没命名表中所有列,未命名的列被设置为它们的缺省值.缺省值赋值在7.7 CREATE TABLE句法中描述. 但不能这样: 如果指定关键词LOW_PRIORITY,INSERT的执行被推迟到没有其他客户正在读取表. 如果在一个有许多值行的INSERT中指定关键词IGNORE,表中任何复制一个现有PRIMARY或UNIQUE键的行被忽略并且不被插入. INSERT INTO ... SELECT语句满足下列条件: INSERT语句的目的表不能出现在SELECT查询部分的FROM子句,因为这在ANSI SQL中被禁止让从正在插入的表中SELECT.(问题是SELECT将可能发现在同一个运行期间内先前被插入的记录.当使用子选择子句时,情况能很容易混淆)MYSQL数据库 AUTO_INCREMENT列象往常一样工作. 插入NULL到被声明了NOT NULL的列,列被设置为它的缺省值. 当使用INSERT DELAYED时,客户将马上准备好,并且当表不被任何其他的线程使用时,行将被插入.MYSQL数据库 另一个使用INSERT DELAYED的主要好处是从很多客户插入被捆绑在一起并且写进一个块.这比做很多单独的插入要来的快.MYSQL数据库 注意,当前排队的行只是存储在内存中,直到他们被插入到表中.这意味着,如果硬要杀死mysqld(kill -9)或如果mysqld出人意料地死掉,没被写进磁盘的任何排队的行被丢失!MYSQL数据库 下列详细描述当为INSERT或REPLACE使用DELAYED选项时,发生什么.在这个描述中,“线程”是收到一个INSERT DELAYED命令的线程并且“处理器”是处理所有对于一个特定表的INSERT DELAYED语句.MYSQL数据库 当一个线程对一个表执行一个DELAYED语句时,如果不存在这样的处理程序,一个处理器线程被创建以处理对于该表的所有DELAYED语句. 线程执行INSERT语句,但不是将行写入表,它把最后一行的副本放进被处理器线程管理的一个队列.任何语法错误都能被线程发觉并报告给客户程序. 当行被插入到表中时,更新日志有处理器线程更新.在多行插入的情况下,当第一行被插入时,更新日志被更新. 当处理器在它的队列中没有更多行时,表被解锁.如果在delayed_insert_timeout秒内没有收到新的INSERT DELAYED命令,处理器终止. 处理器线程将在Command列的MySQL进程表中显示delayed_insert.如果执行一个FLUSH TABLES命令或以KILL thread_id杀死它,它将被杀死,然而,它在退出前首先将所有排队的行存进表中.在这期间,这次它将不从其他线程接受任何新的INSERT命令.如果在它之后执行一个INSERT DELAYED,将创建一个新的处理器线程.MYSQL数据库 注意,如果有一个INSERT DELAYED处理器已经运行,INSERT DELAYED命令有比正常INSERT更高的优先级!其他更新命令将必须等到INSERT DELAY排队变空、杀死处理器线程(用KILL thread_id)或执行FLUSH TABLES.MYSQL数据库 以下的状态变量提供了关于INSERT DELAYED命令的信息: Delayed_insert_threads 处理器线程数量 能通过发出一个SHOW STATUS语句或通过执行一个mysqladmin extended-status命令察看这些变量.MYSQL数据库 注意,如果表不在使用,INSERT DELAYED比一个正常的INSERT慢. 以上就是MYSQL INSERT INTO语句用法的全部内容,希望对大家有所赞助.MYSQL数据库 编程之家PHP培训学院每天发布《Mysql学习Mysql INSERT INTO语句用法详解》等实战技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培养人才。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |