oracle - mysql如何更新一個多表查詢出來的字段
問題描述
$sql = ’SELECT c.is_check’ .’ FROM ’ . $GLOBALS[’ecs’]->table(’goods’) . ’ AS g ’ .’ LEFT JOIN ’ . $GLOBALS[’ecs’]->table(’cart’) . ’ AS c ON c.goods_id = g.goods_id ’ .’ WHERE g.enter_mode = 3105 AND c.user_id = $user_id’;
如上 sql 語句是通過 cart 表和 goods 表的一些條件查詢出 cart 表中符合條件的 is_check 字段。我現在想將這個字段里的值統一更新為我前臺傳過來的 $is_chick,該怎么實現尼?
或者說能不能直接用 updata 語句實現尼?
問題解答
回答1:類似這樣,sql語句你自己需要調試
update cart d set d.is_check = $is_chickwhere exists(SELECT 1 FROM ’ . $GLOBALS[’ecs’]->table(’goods’) . ’ AS g ’ .’ LEFT JOIN ’ . $GLOBALS[’ecs’]->table(’cart’) . ’ AS c ON c.goods_id = g.goods_id ’ .’ WHERE g.enter_mode = 3105 AND c.user_id = $user_id and c.id=d.id)回答2:
update是寫鎖,不建議使用復雜sql。
用你的select語句把 主鍵查出來放到一個list里,然后另一個update cart set ... id in (1,2,3,4) 語句去更新,如果數量大于200,請用批量更新。
回答3:update a inner join (select yy from b) c on a.id =b.id set a.xx = c.yy
把代的sql代入進去
回答4:這個是可以通過update語句實現的
update cart set is_check = value where id in ( select DISTINCT id from (你查詢的條件SQL語句))回答5:
同意@seanlook 的答案,在生產環境中不要寫復雜的SQL,@prolifes 的答案雖然也能達到目的,但如果在高并發和數據量大的情況下有可能造成長時間鎖。
我們公司一般的做法就是先根據條件查出主鍵,再根據主鍵update對應的字段值。
回答6:這個需求可以通過 UPDATE + JOIN 實現,大概的 SQL 如下:
UPDATE goods AS gLEFT JOIN cart AS c ON c.goods_id = g.goods_id SET c.is_check=$is_checkWHERE g.enter_mode = 3105 AND c.user_id = $user_id;
具體可以看我最近寫的一篇文章 https://mp.weixin.qq.com/s?__... 其中有一部分與這個問題有關
相關文章:
1. mysql 查詢身份證號字段值有效的數據2. python bottle跑起來以后,定時執行的任務為什么每次都重復(多)執行一次?3. 視頻文件不能播放,怎么辦?4. html5 - HTML代碼中的文字亂碼是怎么回事?5. python - 爬蟲模擬登錄后,爬取csdn后臺文章列表遇到的問題6. visual-studio - Python OpenCV: 奇怪的自動補全問題7. mysql - 分庫分表、分區、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處8. javascript - 彈出一個子窗口,操作之后關閉,主窗口會得到相應的響應,例如網站的某些登錄界面,django后臺的管理等,這是怎么實現的呢?9. javascript - ios返回不執行js怎么解決?10. android - 分享到微信,如何快速轉換成字節數組
