当前位置:首页 > Mysql教程 > 列表

MySQL 当记录不存在时插入 记录存在时自动更新

发布:smiling 来源: PHP粉丝网  添加日期:2014-09-24 09:54:43 浏览: 评论:0 

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 表,可以使用下面的语句:

  1. INSERT INTO clients 
  2. (client_id, client_name, client_type) 
  3. SELECT supplier_id, supplier_name, supplier_type 
  4. FROM suppliers 
  5. WHERE not exists (select * from clients 
  6. where clients.client_id = suppliers.supplier_id); 

示例二:插入单条记录,代码如下:

  1. INSERT INTO clients 
  2. (client_id, client_name, client_type) 
  3. SELECT 10345, ’IBM’, ’advertising’ 
  4. FROM dual 
  5. WHERE not exists (select * from clients 
  6. where clients.client_id = 10345); 
  7. //开源代码phpfensi.com 

使用 dual 做表名可以让你在 select 语句后面直接跟上要插入字段的值,即使这些值还不存在当前表中,测试性能发现如果同样多的数据使用INSERT ... ON DUPLICATE KEY UPDATE比起not exists是要好很多了,毕竟前者是mysql自带的一个处理重复数据的语句.

Tags: MySQL插入记录 MySQL自动更新

分享到: