您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息
免费发信息
三六零分类信息网 > 克拉玛依分类信息网,免费分类信息发布

MySql更新多条数据不建议使用UPDATE语句

2024/2/20 13:48:29发布20次查看
我们知道当插入多条数据的时候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语法不支持一次更新多条记录
我们知道当插入多条数据的时候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标准语法!
原文地址:mysql更新多条数据不建议使用update语句, 感谢原作者分享。
克拉玛依分类信息网,免费分类信息发布

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录