If Exists INSERT and UPDATE in MySQL

2012/11/15
~ 阿亮 ~

一般 SQL 在做新增資料時,會判斷資料是否已存在,再決定 INSERT or UPDATE.

標準的 SQL 會這麼做

IF EXISTS (SELECT * FROM Table1 WHERE Column1=&#39;SomeValue&#39<img align="center" src="https://derjohng.doitwell.tw/wp-includes/images/yahoo/yahoo3.gif" class="wp-smiley" />
   UPDATE Table1 SET (...) WHERE Column1=&#39;SomeValue&#39;
ELSE
   INSERT INTO Table1 VALUES (...)

或者

UPDATE Table1 SET (...) WHERE Column1=&#39;SomeValue&#39;
IF @@ROWCOUNT=0
    INSERT INTO Table1 VALUES (...)

但 MySQL 下, 以上兩個方法是不會 WORK 的,要用以下 Duplicate Key Update 的做法

INSERT INTO table (a,b,c) VALUES (1,2,3)
  ON DUPLICATE KEY UPDATE c=c+1;

 

這是因為 MySQL 沒有 IF EXISTS 以及 @@ROWCOUNT 。



歡迎留言

敝站會審核留言的適宜性,您的留言可能會較晚發佈,而且小弟保留刪除的權利!!

站內搜尋



本站其他服務

本站其他軟體



  • 藝文快訊

    讓你可以輕鬆追蹤含有您想要關注關鍵詞的任何藝文活動訊息,只要有最新的資訊,「藝文快訊」即會推播通知給你.


  • 下一台單車(NextBike)

    打開定位即搜尋附近二十點自行車站點,不塞滿全部站點資料到整個地圖上,所以畫面簡潔方便看清楚目前所在地,若需要搜尋地圖其他位置附近站點,再點擊地圖即可。


  • 國道一路通(FreeWay)

    打開定位即實際地圖上繪製所在地中心附近的車況圖,可縮放地圖,不再是小小的縮小圖,快速了解高速公路的路況。


  • 台灣匯率快算

    提供全球 150 種以上貨幣即時換算,以及各種匯率歷史變化圖。


  • 當令蔬果花卉(AgriInfo)

    是不是常常在超市看到水果蔬菜的價格,總是不確定是當季蔬果?這個服務就是幫你很快判斷眼前的蔬果花卉的價格是否便宜。


  • 標案快訊

    讓你可以輕鬆追蹤含有您想要關注關鍵詞的任何採購標案,只要有最新的資訊,「標案快訊」即會推播通知給你.