当前位置: 移动技术网 > IT编程>数据库>Mysql > MySql中使用INSERT INTO语句更新多条数据的例子

MySql中使用INSERT INTO语句更新多条数据的例子

2017年12月12日  | 移动技术网IT编程  | 我要评论

炸药爆炸,监狱培欲,谢巧丹

我们知道当插入多条数据的时候insert支持多条语句:

复制代码 代码如下:

insert into t_member (id, name, email) values
    (1, 'nick', 'nick@126.com'),
    (4, 'angel','angel@163.com'),
    (7, 'brank','ba198@126.com');

但是对于更新记录,由于update语法不支持一次更新多条记录,只能一条一条执行:

复制代码 代码如下:

update t_member set name='nick', email='nick@126.com' where id=1;
update t_member set name='angel', email='angel@163.com' where id=4;
update t_member set name='brank', email='ba198@126.com' where id=7;

这里问题就出现了,倘若这个update list非常大时(譬如说5000条),这个执行率可想而知。

这就要介绍一下在mysql中insert语法具有一个条件duplicate key update,这个语法和适合用在需要判断记录是否存在,不存在则插入存在则更新的记录。

具体的语法可以参见:http://dev.mysql.com/doc/refman/5.0/en/insert.html

基于上面这种情况,针对更新记录,仍然使用insert语句,不过限制主键重复时,更新字段。如下:

复制代码 代码如下:

insert into t_member (id, name, email) values
    (1, 'nick', 'nick@126.com'),
    (4, 'angel','angel@163.com'),
    (7, 'brank','ba198@126.com')
on duplicate key update name=values(name), email=values(email);

注意:on duplicate key update只是mysql的特有语法,并不是sql标准语法!

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网