亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

SQLite INSERT - ON DUPLICATE KEY UPDATE(UPSERT)

SQLite INSERT - ON DUPLICATE KEY UPDATE(UPSERT)

收到一只叮咚 2019-07-31 18:51:10
SQLite INSERT - ON DUPLICATE KEY UPDATE(UPSERT)MySQL有這樣的東西:INSERT INTO visits (ip, hits)VALUES ('127.0.0.1', 1)ON DUPLICATE KEY UPDATE hits = hits + 1;據我所知,SQLite中不存在此功能,我想知道的是,如果有任何方法可以實現相同的效果而無需執行兩個查詢。此外,如果無法做到這一點,您更喜歡什么:SELECT +(INSERT或UPDATE)或更新(如果UPDATE失敗,則為 + INSERT )
查看完整描述

3 回答

?
達令說

TA貢獻1821條經驗 獲得超6個贊

從3.24.0開始,SQLite也支持upsert,所以現在你可以簡單地編寫以下內容


INSERT INTO visits (ip, hits)

VALUES ('127.0.0.1', 1)

ON CONFLICT(ip) DO UPDATE SET hits = hits + 1;


查看完整回答
1 反對 回復 2019-07-31
?
慕的地8271018

TA貢獻1796條經驗 獲得超4個贊

INSERT OR IGNORE INTO visits VALUES ($ip, 0);UPDATE visits SET hits = hits + 1 WHERE ip LIKE $ip;

這要求“ip”列具有UNIQUE(或PRIMARY KEY)約束。


查看完整回答
反對 回復 2019-07-31
?
慕雪6442864

TA貢獻1812條經驗 獲得超5個贊

我更喜歡UPDATE (+ INSERT if UPDATE fails)。更少的代碼=更少的錯誤。


查看完整回答
反對 回復 2019-07-31
  • 3 回答
  • 0 關注
  • 3307 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號