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;
例子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);
- //开源代码phpfensi.com
使用 dual 做表名可以让你在 select 语句后面直接跟上要插入字段的值,即使这些值还不存在当前表中,测试性能发现如果同样多的数据使用INSERT ... ON DUPLICATE KEY UPDATE比起not exists是要好很多了,毕竟前者是mysql自带的一个处理重复数据的语句.
Tags: MySQL插入记录 MySQL自动更新
相关文章
- ·Mysql插入记录 instert语句详解(2014-10-01)
- ·MySQL避免重复插入记录方法总结(2014-10-01)
- ·mysql防止重复插入记录方法总结(2014-10-02)
- ·mysql中插入记录时不存在时插入已经存在则更新(2014-10-09)
- ·MySQL的timestamp类型自动更新(2014-10-10)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)