1. 程式人生 > >SQL實現沒有這條資料就新增,有這條資料就修改

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