mysql大量数据更新采用什么样的方式比较好,20w条数据一次更新?

mysql大量数据更新采用什么样的方式比较好,20w条数据一次更新?,第1张

建缓冲区。比如其他类型的高速缓存(redis等)作为中间缓冲层。数据的查询,更改首先在这个层处理,处理完再更新到对应的数据库。注意额外增加锁,或者缓存机制防止缓存击穿,雪崩导致系统崩溃。

我们知道当插入多条数据的时候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标准语法!

呵呵,一楼方法确实可以用,只是在具体解决问题当中却不会那么去用,一般来说,你要更新某字段,都是更新某一类属性中某个具体字段,就比如说你想更新某考生考号最近记录,而不会是去更新所有记录当中最近记录,

以下创建的是一个考号更新触发器,其更新考生信息表中某考生考号,而update其中要使用到参数 @" ",其默认更新最近一条记录。仅供参考

create trigger yonghu

on 考生信息 for update

as

declare @kaohao9 varchar(40)

if update (考号)

begin

if not exists (select * from 考生信息 where 考号=

(select 考号 from inserted))

begin

raiserror ('非法考号!',15,1)

rollback transaction

end

select 考号 from inserted

where @kaohao9= 考号

update 考生情况 set 考号= @kaohao9

update 试卷 set 考号= @kaohao9

end


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存