亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

oracle - mysql如何更新一個多表查詢出來的字段

瀏覽:122日期:2022-06-21 14:22:24

問題描述

$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?__... 其中有一部分與這個問題有關

相關文章:
主站蜘蛛池模板: 欧美日韩在线观看一区 | 欧美另类色| 久草社区视频 | 国产成人福利免费观看 | 亚洲成人午夜影院 | 一级毛片免费在线播放 | 国产精品免费久久 | 艳女伦交一级毛片 | 好看的亚洲视频 | 亚洲第一男人天堂 | 久久精品道一区二区三区 | 99精品久久99久久久久久 | 国产一级在线 | 国产精品亚洲专区在线播放 | 国产成人综合精品一区 | 国产精品中文字幕在线观看 | 做爰www免费看视频 1024色淫免费视频 | 美女作爱网站 | 日本免费一区二区三区三州 | 免费一级欧美片在线观免看 | 国产精品久久久久国产精品三级 | 日本高清在线不卡 | 欧美成人a | 国产精品欧美视频另类专区 | 国产成人精品日本亚洲语音1 | 自拍一页| 视频二区在线观看 | 欧美二级在线观看免费 | 欧美xxxx色视频在线观看 | 欧美日韩精彩视频 | 亚洲美女视频 | 丝袜紧身裙国产在线播放 | 国产精品久久久久久久久久影院 | 欧美精品xxx | 国产午夜a理论毛片在线影院 | 国产精选经典三级小泽玛利亚 | 最新国产精品好看的国产精品 | 黄色a站| 中国女人毛茸茸免费视频 | 成人夜色视频网站在线观看 | 2021国产精品自在拍在线播放 |