MySQL 一条SQL同时UPDATE多条记录

MySQL 一条SQL同时UPDATE多条记录,第1张

UPDATE tableNmae SET columnName = value WHERE columnName = otherValue

UPDATE tableNmae SET columnName = value WHERE columnName IN (otherValue1, otherValue2)

当然还有其他写法,这里只是举个例子。

首先要使用 IN 限定修改的数据,不使用 IN 的话在此语句中未进行设置值的会变成 NULL 或者默认值。

该语句会将 column2 值为相应 column2Value 的数据 column1 字段修改为对应的 column1Value 。

mysql更新10万条数据要三个多小时。根据查询相关公开信息,批量更新表中某个字段,如果表比较大,每条记录都执行一条update,1秒执行10条数据,10万条数据就要1W秒,3个多小时。

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

复制代码

代码如下:

INSERT

INTO

t_member

(id,

name,

email)

VALUES

(1,

'nick',

'[email protected]'),

(4,

'angel','[email protected]'),

(7,

'brank','[email protected]')

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

复制代码

代码如下:

UPDATE

t_member

SET

name='nick',

email='[email protected]'

WHERE

id=1

UPDATE

t_member

SET

name='angel',

email='[email protected]'

WHERE

id=4

UPDATE

t_member

SET

name='brank',

email='[email protected]'

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',

'[email protected]'),

(4,

'angel','[email protected]'),

(7,

'brank','[email protected]')

ON

DUPLICATE

KEY

UPDATE

name=VALUES(name),

email=VALUES(email)

注意:ON

DUPLICATE

KEY

UPDATE只是MySQL的特有语法,并不是SQL标准语法!


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5905330.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-07
下一篇 2023-03-07

发表评论

登录后才能评论

评论列表(0条)

保存