SQL實現沒有這條資料就新增,有這條資料就修改
阿新 • • 發佈:2018-11-01
方法一: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
1
from
表
where
ID = @ID)
begin
update
表
set
XX= XX
where
ID = @ID
end
else
begin
insert
表
values
(XX...)
end