簡體   English   中英

SQL:用同一張表的結果更新多行

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM