[英]SQL: Update multiple rows with result from same table
我正在嘗試使用同一表的一行中的可用值更新表的多行中的字段(post_id)。 該表是一個WordPress表wp_meta
這是表格的結構
meta_id | post_id | meta_key | meta_value
1 16 author "Staff"
2 16 title "title"
3 16 old_id 250
4 17 author "jay"
5 17 old_id 251
6 18 author "panda"
7 18 title "realy nice"
8 18 old_id 252
9 18 some_key lorem"
我希望這樣,以便將post_id替換為該對應帖子集的old_id。 結果應該是這樣的
meta_id | post_id | meta_key | meta_value
1 250 author "Staff"
2 250 title "title"
3 250 old_id 250
4 251 author "jay"
5 251 old_id 251
6 252 author "panda"
7 252 title "realy nice"
8 252 old_id 252
9 252 some_key lorem"
這是我正在嘗試的方法,但這是錯誤的
UPDATE wprk_postmeta as t1
SET post_id = (SELECT t2.meta_value from wprk_postmeta as t2 WHERE t2.meta_key='old_id' AND t2.post_id=t1.post_id)
當我運行上面的代碼時,我得到的子查詢返回了多個值錯誤。
我想你想join
:
UPDATE wprk_postmeta pm JOIN
work_postmeta pmo
ON pm.post_id = pmo.post_id AND
pmo.meta_key = 'old_id'
SET post_id = pmo.meta_value;
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.