复制代码
代码如下:
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
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)