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

方法一: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

猜你喜欢

转载自blog.csdn.net/qq_36264795/article/details/81049511