mes*_*eeb 1 mysql select insert insert-select sql-insert
我需要清理我的 MySQL 数据库并根据当前状态创建大量新记录。我需要插入这个:
INSERT INTO wp_postmeta (post_id, meta_key, meta_value) VALUES ($ID, "price_input_currency", "usd")
Run Code Online (Sandbox Code Playgroud)
对于我从该选择中获得的每个 $ID:
SELECT ID FROM wp_posts AS posts
RIGHT JOIN wp_postmeta ON posts.ID = post_id
WHERE post_type = 'post'
AND meta_value LIKE '%$%' AND meta_key = 'price_range'
Run Code Online (Sandbox Code Playgroud)
仅通过 MySQL 代码就可以做到这一点吗?我见过很多“如何将 INSERT 与 SELECT 结合起来,但他们都没有只使用字符串来插入,他们总是选择需要插入的所有字段......有什么想法吗?
您可以使用该INSERT INTO...SELECT构造,其中meta_key和meta_value列具有常量字符串值:
INSERT INTO wp_postmeta (post_id, meta_key, meta_value)
SELECT ID, 'price_input_currency', 'usd'
FROM wp_posts AS posts
RIGHT JOIN wp_postmeta
ON posts.ID = post_id
WHERE post_type = 'post' AND
meta_value LIKE '%$%' AND meta_key = 'price_range'
Run Code Online (Sandbox Code Playgroud)