如何更新同一表的子查询中的列并将值设置为

发布于 2024-11-09 09:22:26 字数 389 浏览 0 评论 0原文

我无法让这个 SQL 工作。基本上我想UPDATEsort_order并将其设置为由同一个表上的子查询选择的parents_sort_order。这是我的 SELECT 查询,显示了我需要的数据...

SELECT p.id,p.sort_order,p.parent_id, (
  SELECT `sort_order` AS parent_sort_order
  FROM `product`
  WHERE id = p.parent_id
)
FROM  `product` p
WHERE p.dealer_id !=0
AND p.vendor_id >100

谢谢!

I'm having trouble getting this SQL to work. Basically I want to UPDATE the column sort_order and set it to the parents_sort_order which is selected by a subquery on the same table. Here's my SELECT query showing the data I need....

SELECT p.id,p.sort_order,p.parent_id, (
  SELECT `sort_order` AS parent_sort_order
  FROM `product`
  WHERE id = p.parent_id
)
FROM  `product` p
WHERE p.dealer_id !=0
AND p.vendor_id >100

Thanks!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

青衫负雪 2024-11-16 09:22:26

您选择的加入版本:

SELECT p.id,p.sort_order,p.parent_id, b.sort_order as parent_sort_order
FROM  `product` p join `product` b
on p.id = b.parent_id
WHERE p.dealer_id !=0
AND p.vendor_id >100

更新选项 1:

update product a, product b set a.sort_order = b.parent_sort_order
where a.id = b.parent_id
and a.dealer_id !=0
and a.vendor_id > 100

更新选项 2:

update product a left join product b on a.id = b.parent_id 
set a.sort_order = b.parent_sort_order
where a.dealer_id !=0
and a.vendor_id > 100

Join version of your select:

SELECT p.id,p.sort_order,p.parent_id, b.sort_order as parent_sort_order
FROM  `product` p join `product` b
on p.id = b.parent_id
WHERE p.dealer_id !=0
AND p.vendor_id >100

Update Option 1:

update product a, product b set a.sort_order = b.parent_sort_order
where a.id = b.parent_id
and a.dealer_id !=0
and a.vendor_id > 100

Update Option 2:

update product a left join product b on a.id = b.parent_id 
set a.sort_order = b.parent_sort_order
where a.dealer_id !=0
and a.vendor_id > 100
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文