首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用不同的行值使用一个查询更新多行

使用不同的行值使用一个查询更新多行
EN

Stack Overflow用户
提问于 2015-02-05 19:20:41
回答 1查看 101关注 0票数 0

我不知道怎么清楚地命名这个。

在使用shared_id连接表本身之后,我得到以下数据。

代码语言:javascript
复制
a.id   | a.shared_id | a.key     | a.value         | b.id   | b.shared_id | b.key       | b.value
198131 | 6044        | unique-id | E15SJOEMGRMH013 | 198281 |6044         | _unique_id  |

这是由于:

代码语言:javascript
复制
SELECT * FROM
(SELECT * FROM table1 WHERE key='unique-id') AS a
JOIN
(SELECT * FROM table1 WHERE key='_unique_id') AS b
ON a.shared_id = b.shared_id
WHERE a.value!='' AND a.value!=b.value AND a.key='unique-id'
;

我需要的是一个update语句,它将b.value设置为a.values value.So,在这个1行示例中,我希望b.value是E15SJOEMGRMH013

现在请记住,a.id和b.id并不是相同的,因为键的名称略有不同,但是它们应该保持相同的值。有几百行,所以我想在一个更新查询中这样做。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-02-05 19:34:14

您不需要子查询,而您对它们的使用可能就是无法计算出相应的UPDATE查询的原因。

代码语言:javascript
复制
UPDATE table1 AS a
JOIN table1 AS b ON a.shared_id = b.shared_id
SET b.value = a.value
WHERE a.key = 'unique-id' AND b.key = '_unique_id'
    AND a.value != ''

SELECT应该简单地:

代码语言:javascript
复制
SELECT *
FROM table1 AS a
JOIN table1 AS b ON a.shared_id = b.shared_id AND a.value != b.value
WHERE a.key = 'unique-id' AND b.key = '_unique_id'
    AND a.value != ''

您不需要在a.value != b.value中使用UPDATE子句--如果它们是相同的,UPDATE什么也不做。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28352257

复制
相关文章

相似问题

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