oracle - mysql如何更新一個(gè)多表查詢出來(lái)的字段
問(wèn)題描述
$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 語(yǔ)句是通過(guò) cart 表和 goods 表的一些條件查詢出 cart 表中符合條件的 is_check 字段。我現(xiàn)在想將這個(gè)字段里的值統(tǒng)一更新為我前臺(tái)傳過(guò)來(lái)的 $is_chick,該怎么實(shí)現(xiàn)尼?
或者說(shuō)能不能直接用 updata 語(yǔ)句實(shí)現(xiàn)尼?
問(wèn)題解答
回答1:類似這樣,sql語(yǔ)句你自己需要調(diào)試
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是寫(xiě)鎖,不建議使用復(fù)雜sql。
用你的select語(yǔ)句把 主鍵查出來(lái)放到一個(gè)list里,然后另一個(gè)update cart set ... id in (1,2,3,4) 語(yǔ)句去更新,如果數(shù)量大于200,請(qǐng)用批量更新。
回答3:update a inner join (select yy from b) c on a.id =b.id set a.xx = c.yy
把代的sql代入進(jìn)去
回答4:這個(gè)是可以通過(guò)update語(yǔ)句實(shí)現(xiàn)的
update cart set is_check = value where id in ( select DISTINCT id from (你查詢的條件SQL語(yǔ)句))回答5:
同意@seanlook 的答案,在生產(chǎn)環(huán)境中不要寫(xiě)復(fù)雜的SQL,@prolifes 的答案雖然也能達(dá)到目的,但如果在高并發(fā)和數(shù)據(jù)量大的情況下有可能造成長(zhǎng)時(shí)間鎖。
我們公司一般的做法就是先根據(jù)條件查出主鍵,再根據(jù)主鍵update對(duì)應(yīng)的字段值。
回答6:這個(gè)需求可以通過(guò) UPDATE + JOIN 實(shí)現(xiàn),大概的 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;
具體可以看我最近寫(xiě)的一篇文章 https://mp.weixin.qq.com/s?__... 其中有一部分與這個(gè)問(wèn)題有關(guān)
相關(guān)文章:
1. mysql - 記得以前在哪里看過(guò)一個(gè)估算時(shí)間的網(wǎng)站2. 關(guān)docker hub上有些鏡像的tag被標(biāo)記““This image has vulnerabilities””3. docker綁定了nginx端口 外部訪問(wèn)不到4. dockerfile - 為什么docker容器啟動(dòng)不了?5. angular.js - angular內(nèi)容過(guò)長(zhǎng)展開(kāi)收起效果6. javascript - 能否讓vue-cli的express修改express重啟服務(wù)7. macos - mac下docker如何設(shè)置代理8. docker鏡像push報(bào)錯(cuò)9. docker內(nèi)創(chuàng)建jenkins訪問(wèn)另一個(gè)容器下的服務(wù)器問(wèn)題10. 請(qǐng)教各位大佬,瀏覽器點(diǎn) 提交實(shí)例為什么沒(méi)有反應(yīng)
