首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有2x的mysql多次更新

带有2x的mysql多次更新
EN

Stack Overflow用户
提问于 2016-12-06 05:07:09
回答 2查看 38关注 0票数 0

我尝试在一个查询中获得多个Mysql更新查询,我有3个测试查询。

代码语言:javascript
复制
UPDATE `stock` SET `date_time_out`='2016-12-05 13:47:05' WHERE `weighting_id` = '80' AND `date_time_out` = '0000-00-00 00:00:00'
UPDATE `stock` SET `date_time_out`='2016-12-05 13:46:05' WHERE `weighting_id` = '79' AND `date_time_out` = '0000-00-00 00:00:00'
UPDATE `stock` SET `date_time_out`='2016-12-05 13:45:05' WHERE `weighting_id` = '78' AND `date_time_out` = '0000-00-00 00:00:00'

我已经创建了下面的查询,但它不起作用

代码语言:javascript
复制
UPDATE `stock` 
SET value = CASE
WHEN  `weighting_id` = '80' AND `date_time_out` = '0000-00-00 00:00:00' THEN '2016-12-05 13:47:05'
WHEN  `weighting_id` = '79' AND `date_time_out` = '0000-00-00 00:00:00' THEN '2016-12-05 13:46:05'
WHEN  `weighting_id` = '78' AND `date_time_out` = '0000-00-00 00:00:00' THEN '2016-12-05 13:45:05'
ELSE VALUE
END
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-12-06 05:21:53

我找到了答案,下面的代码工作正常:

代码语言:javascript
复制
UPDATE `stock` 
SET `date_time_out` = CASE
WHEN  `weighting_id` = '70' AND `date_time_out` = '0000-00-00 00:00:00' THEN '2016-12-05 13:47:05'
WHEN  `weighting_id` = '71' AND `date_time_out` = '0000-00-00 00:00:00' THEN '2016-12-05 13:48:05'
WHEN  `weighting_id` = '72' AND `date_time_out` = '0000-00-00 00:00:00' THEN '2016-12-05 13:48:05'
WHEN  `weighting_id` = '73' AND `date_time_out` = '0000-00-00 00:00:00' THEN '2016-12-05 13:48:05'
WHEN  `weighting_id` = '74' AND `date_time_out` = '0000-00-00 00:00:00' THEN '2016-12-05 13:48:05'
WHEN  `weighting_id` = '75' AND `date_time_out` = '0000-00-00 00:00:00' THEN '2016-12-05 13:48:05'
ELSE `date_time_out`
END

WHERE `weighting_id` IN ('70', '71', '72', '73', '74', '75') AND `date_time_out` IN ('0000-00-00 00:00:00')

该代码比5个单独的更新查询快100倍-150倍。

票数 0
EN

Stack Overflow用户

发布于 2016-12-06 05:10:50

你能这样做吗?

代码语言:javascript
复制
   UPDATE `stock` 
    SET value = (CASE
    WHEN  `weighting_id` = '80' THEN '2016-12-05 13:47:05'
    WHEN  `weighting_id` = '79' THEN '2016-12-05 13:46:05'
    WHEN  `weighting_id` = '78' THEN '2016-12-05 13:45:05'         
    END
    ) WHERE weighting_id in ('80','79','78') AND `date_time_out` = '0000-00-00 00:00:00'
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40988211

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档