主键冲突的话就更新否则插入 (ON DUPLICATE KEY UPDATE )
来源:互联网 发布:js打开excel文件 编辑:程序博客网 时间:2024/05/20 06:37
INSERT INTO user_tag_exp (uid,tag,detail)VALUES(?,?,?) ON DUPLICATE KEY UPDATE detail=?
看程序竟然发现Mysql有这个功能!
以前写的程序呀……………………
MySQL 自4.1版以后开始支持INSERT … ON DUPLICATE KEY UPDATE语法,使得原本需要执行3条SQL语句(SELECT,INSERT,UPDATE),缩减为1条语句即可完成。
INSERT ... ON DUPLICATE KEY UPDATE,当插入的记录会引发主键冲突或者违反唯一约束时,则使用UPDATE更新旧的记录,否则插入新记录。
例如ipstats表结构如下:
CREATE TABLE ipstats (ip VARCHAR(15)NOT NULLUNIQUE,clicks SMALLINT(5)UNSIGNEDNOT NULLDEFAULT'0');原本需要执行3条SQL语句,如下:
IF(SELECT * FROM ipstats WHERE ip='192.168.0.1'){UPDATE ipstats SET clicks=clicks+1WHERE ip='192.168.0.1';} else {INSERTINTO ipstats (ip, clicks)VALUES('192.168.0.1', 1);}而现在只需下面1条SQL语句即可完成:
INSERTINTO ipstats VALUES('192.168.0.1', 1) ON DUPLICATE KEY UPDATE clicks=clicks+1;注意,要使用这条语句,前提条件是这个表必须有一个唯一索引或主键。
再看一例子:
mysql> desc test;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| uid | int(11) | NO | PRI | | |
| uname | varchar(20) | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec)
mysql> select * from test;
+-----+--------+
| uid | uname |
+-----+--------+
| 1 | uname1 |
| 2 | uname2 |
| 3 | me |
+-----+--------+
3 rows in set (0.00 sec)
mysql> INSERT INTO test values ( 3,'insertName' )
-> ON DUPLICATE KEY UPDATE uname='updateName';
Query OK, 2 rows affected (0.03 sec)
mysql> select * from test;
+-----+------------+
| uid | uname |
+-----+------------+
| 1 | uname1 |
| 2 | uname2 |
| 3 | updateName |
+-----+------------+
3 rows in set (0.00 sec)
mysql> create index i_test_uname on test(uname);
Query OK, 3 rows affected (0.20 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql> INSERT INTO test VALUES ( 1 , 'uname2')
-> ON DUPLICATE KEY UPDATE uname='update2records';
Query OK, 2 rows affected (0.00 sec)
mysql> select * from test;
+-----+----------------+
| uid | uname |
+-----+----------------+
| 2 | uname2 |
| 1 | update2records |
| 3 | updateName |
+-----+----------------+
3 rows in set (0.00 sec)
插入时会与两条记录发生冲突,分别由主键和唯一索引引起。但最终只UPDATE了其中一条。这在手册中也说明了,有多个唯一索引(或者有键也有唯一索引)的情况下,不建议使用该语句。
来自:http://hi.baidu.com/wxj_man/item/218f01952c106f5ef14215e7
- 主键冲突的话就更新否则插入 (ON DUPLICATE KEY UPDATE )
- MySQL_插入更新 ON DUPLICATE KEY UPDATE
- MySql 的ON DUPLICATE KEY UPDATE函数(有记录就更新,没记录就插入)
- mysql重复插入insert时更新ON DUPLICATE KEY UPDATE
- mysql重复插入insert时更新ON DUPLICATE KEY UPDATE
- mysql-ignore、replace、on duplicate key update(不存在则插入,存在则更新)
- ON DUPLICATE KEY UPDATE 附带更新条件
- mybatis批量更新(on duplicate key update)
- ON DUPLICATE KEY UPDATE 附带更新条件
- 记录:mysql中的case when|on duplicate key update|重复插入返回主键的用法
- MySQL 当记录不存在时插入,当记录存在时更新 ON DUPLICATE KEY UPDATE
- INSERT ... ON DUPLICATE KEY UPDATE 插入或者更新一起写 。掉咋天
- MySQL记录存在则更新,不存在插入on duplicate key update
- ON DUPLICATE KEY UPDATE
- on duplicate key update
- ON DUPLICATE KEY UPDATE
- ON DUPLICATE KEY UPDATE
- ON DUPLICATE KEY UPDATE
- php基础系列:PHP连接MySQL数据库用到的三种API
- STL学习小结
- 织梦CMS(dedecms)栏目属性及系统封面模板、列表模板、文章模板区别和路径设置解答
- 告诉那些个创业迷茫找不着方向的人
- 这样用css写渐变,兼容所有主流浏览器
- 主键冲突的话就更新否则插入 (ON DUPLICATE KEY UPDATE )
- MyEclipse注册码生成代码
- sql server 索引简单使用
- Project Baselines and the Triple Constraints
- 网络编程学习小结
- S5PV210的启动过程
- 网络游戏服务器架构
- 【百度地图API】如何制作多途经点的线路导航——驾车篇
- Usb设备驱动2:root hub守护进程1