久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:129日期: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 字段。我現(xiàn)在想將這個字段里的值統(tǒng)一更新為我前臺傳過來的 $is_chick,該怎么實(shí)現(xiàn)尼?

或者說能不能直接用 updata 語句實(shí)現(xiàn)尼?

問題解答

回答1:

類似這樣,sql語句你自己需要調(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是寫鎖,不建議使用復(fù)雜sql。

用你的select語句把 主鍵查出來放到一個list里,然后另一個update cart set ... id in (1,2,3,4) 語句去更新,如果數(shù)量大于200,請用批量更新。

回答3:

update a inner join (select yy from b) c on a.id =b.id set a.xx = c.yy

把代的sql代入進(jìn)去

回答4:

這個是可以通過update語句實(shí)現(xiàn)的

update cart set is_check = value where id in ( select DISTINCT id from (你查詢的條件SQL語句))回答5:

同意@seanlook 的答案,在生產(chǎn)環(huán)境中不要寫復(fù)雜的SQL,@prolifes 的答案雖然也能達(dá)到目的,但如果在高并發(fā)和數(shù)據(jù)量大的情況下有可能造成長時間鎖。

我們公司一般的做法就是先根據(jù)條件查出主鍵,再根據(jù)主鍵update對應(yīng)的字段值。

回答6:

這個需求可以通過 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;

具體可以看我最近寫的一篇文章 https://mp.weixin.qq.com/s?__... 其中有一部分與這個問題有關(guān)

相關(guān)文章:
主站蜘蛛池模板: 托克逊县| 新绛县| 马尔康县| 崇文区| 庆元县| 喜德县| 巴东县| 南安市| 肥东县| 咸阳市| 民权县| 康平县| 罗山县| 岑溪市| 翁牛特旗| 安丘市| 镇康县| 湾仔区| 奉新县| 禄丰县| 澎湖县| 榆树市| 和顺县| 深水埗区| 巴彦县| 黄冈市| 福州市| 泰宁县| 万荣县| 易门县| 邓州市| 兰溪市| 古交市| 兴海县| 武隆县| 松江区| 石家庄市| 林周县| 辽宁省| 临清市| 玛纳斯县|