SQL实现没有这条数据就添加,有这条数据就修改

来源:互联网 发布:网络双生是什么意思 编辑:程序博客网 时间:2024/05/18 01:10

方法一:insert into on duplicate key update

 举个例子,字段a被定义为UNIQUE,并且原数据库表table中已存在记录(2,2,9)和(3,2,1),如果插入记录的a值与原有记录重复,则更新原有记录,否则插入新行:






INSERT INTO TABLE (a,b,c) VALUES 
(1,2,3),
(2,5,7),
(3,3,6),
(4,8,2)
ON DUPLICATE KEY UPDATE b=VALUES(b);

     以上SQL语句的执行,发现(2,5,7)中的a与原有记录(2,2,9)发生唯一值冲突,则执行ON DUPLICATE KEY UPDATE,将原有记录(2,2,9)更新成(2,5,9),将(3,2,1)更新成(3,3,1),插入新记录(1,2,3)和(4,8,2)

方法二:创建存储过程

   create procedure name()

if exists(select from 表 where ID = @ID)
begin
   update 表 set XX= XX where ID = @ID
end
else
begin
   insert 表 values(XX...) 
end

0 0