A-A+
MySQL 当记录不存在时插入 记录存在时自动更新
MySQL当记录不存在时插入,记录存在时自动更新的方法有很多,下面文章总结了两种技巧,一种是mysql自带的INSERT ... ON DUPLICATE KEY UPDATE另一种方法是not exists了,下面一起来看一下吧.
重要的就是上面提到的:INSERT ... SELECT,INSERT ... ON DUPLICATE KEY UPDATE,INSERT ... ON DUPLICATE REPLACE
比如想往表中插入一条数据,如果表中没有该条数据才插入,如果已经存在该条数据就不插入.
首先,在创建表时,将不需要重复的字段设置为unique,然后在插入时,使用insert ignore语句.
MySQL实现(Duplicate key)如果不存在则插入,存在则更新:
INSERT INTO ipstats VALUES(’192.168.0.1′, 1) ON DUPLICATE KEY UPDATE clicks=clicks+1;
例子,代码如下:
- mysql> insert into `200702` (`domain`, `2nd_domain`, `tld`, `query_ns1`, `query_ns2`, `report_date`) values ('dnspod.com', 'dnspod', 'com', 1000, 2000, '2007-02-04') ON DUPLICATE KEY UPDATE `query_ns1` = `query_ns1` + 1000, `query_ns2` = `query_ns2` + 2000;
- Query OK, 2 rows affected (0.01 sec)
例子2,代码如下:
- ysql> insert into `200702` (`domain`, `2nd_domain`, `tld`, `query_ns1`, `query_ns2`, `report_date`) values ('dnspod.com', 'dnspod', 'com', 1000, 2000, '2007-02-04') ON DUPLICATE KEY UPDATE `query_ns1` = `query_ns1` + 1000, `query_ns2` = `query_ns2` + 2000;
- Query OK,1 row affected (0.00 sec)
除了使用INSERT ... ON DUPLICATE KEY UPDATE我们还可以使用(insert if not exists)
示例一:插入多条记录,假设有一个主键为 client_id 的 clients 表,可以使用下面的语句:
- INSERT INTO clients
- (client_id, client_name, client_type)
- SELECT supplier_id, supplier_name, supplier_type
- FROM suppliers
- WHERE not exists (select * from clients
- where clients.client_id = suppliers.supplier_id);
示例二:插入单条记录,代码如下:
- INSERT INTO clients
- (client_id, client_name, client_type)
- SELECT 10345, ’IBM’, ’advertising’
- FROM dual
- WHERE not exists (select * from clients
- where clients.client_id = 10345);
- //开源代码www.xiariboke.net
使用 dual 做表名可以让你在 select 语句后面直接跟上要插入字段的值,即使这些值还不存在当前表中,测试性能发现如果同样多的数据使用INSERT ... ON DUPLICATE KEY UPDATE比起not exists是要好很多了,毕竟前者是mysql自带的一个处理重复数据的语句.