on duplicate key update,不重复写入的一个语法.docx
《on duplicate key update,不重复写入的一个语法.docx》由会员分享,可在线阅读,更多相关《on duplicate key update,不重复写入的一个语法.docx(5页珍藏版)》请在三一办公上搜索。
1、on duplicate key update,不重复写入的一个语法MySQL 当记录不存在时插入,当记录存在时更新 MySQL 当记录不存在时插入,当记录存在时更新 网上基本有三种解决方法。 第一种: 示例一:插入多条记录 假设有一个主键为 client_id 的 clients 表,可以使用下面的语句: INSERTINTOclients (client_id,client_name,client_type) SELECTsupplier_id,supplier_name,advertising FROMsuppliers WHEREnotexists(select*fromclients
2、 whereclients.client_id=suppliers.supplier_id); 示例一:插入单条记录 INSERTINTOclients (client_id,client_name,client_type) SELECT10345,IBM,advertising FROMdual WHEREnotexists(select*fromclients whereclients.client_id=10345); 使用 dual 做表名可以让你在 select 语句后面直接跟上要插入字段的值,即使这些值还不存在当前表中。 第二种: INSERT 中ON DUPLICATE KEY
3、UPDATE的使用 如果您指定了ON DUPLICATE KEY UPDATE,并且插入行后会导致在一个UNIQUE索引或PRIMARY KEY中出现重复值,则执行旧行UPDATE。例如,如果列a被定义为UNIQUE,并且包含值1,则以下两个语句具有相同的效果: mysqlINSERT INTO table (a,b,c) VALUES (1,2,3) -ON DUPLICATE KEY UPDATE c=c+1; mysqlUPDATE table SET c=c+1 WHERE a=1; 如果行作为新记录被插入,则受影响行的值为1;如果原有的记录被更新,则受影响行的值为2。 注释:如果列b
4、也是唯一列,则INSERT与此UPDATE语句相当: mysqlUPDATE table SET c=c+1 WHERE a=1 OR b=2 LIMIT 1; 如果a=1 OR b=2与多个行向匹配,则只有一个行被更新。通常,您应该尽量避免对带有多个唯一关键字的表使用ON DUPLICATE KEY子句。 您可以在UPDATE子句中使用VALUES(col_name)函数从INSERT.UPDATE语句的INSERT部分引用列值。换句话说,如果没有发生重复关键字冲突,则UPDATE子句中的VALUES(col_name)可以引用被插入的col_name的值。本函数特别适用于多行插入。VALU
5、ES函数只在INSERT.UPDATE语句中有意义,其它时候会返回NULL。 示例: mysqlINSERT INTO table (a,b,c) VALUES (1,2,3),(4,5,6) -ON DUPLICATE KEY UPDATE c=VALUES(a)+VALUES(b); 本语句与以下两个语句作用相同: mysqlINSERT INTO table (a,b,c) VALUES (1,2,3) -ON DUPLICATE KEY UPDATE c=3; mysqlINSERT INTO table (a,b,c) VALUES (4,5,6) -ON DUPLICATE KEY
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- on duplicate key update 不重复写入的一个语法 update 重复 写入 一个 语法
链接地址:https://www.31ppt.com/p-3061823.html