微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在单个MySQL查询中获取带有POST META的帖子ID

如何解决在单个MySQL查询中获取带有POST META的帖子ID

从POSTS-> ID中,我想要前12个ID,其中post_type ='product' 通过该ID关联,我想获取所有POST Meta

我正在使用此MySQL查询,但它不起作用:

SELECT posts.ID,postMeta.Meta_key,postMeta.Meta_value FROM `wp_u8gwgg_posts` as posts

INNER JOIN wp_u8gwgg_postMeta as postMeta on posts.ID = postMeta.post_id

WHERE 

posts.`post_type` = 'product' AND 
posts.post_status = 'publish'

ORDER BY posts.ID

这给了我多余的数据post_id。

Post ID | Meta Key       | Meta Value
++++++++++++++++++++++++++++++++++++++
12      | _sku           | 18945236
12      | _price         | 1569.36
12      | _regular_price | 1496.20

我希望结果为:

Post ID | Meta Key                     | Meta Value
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
12      | _sku,_price,_regular_price | 18945236,1569.36,1496.20

如果可能,请让我解决

OR

如果有更好的解决方法,也欢迎您。

谢谢

解决方法

SELECT posts.ID,GROUP_CONCAT(postmeta.meta_key ORDER BY posts.ID) meta_keys,GROUP_CONCAT(postmeta.meta_value ORDER BY posts.ID) meta_values 
FROM wp_u8gwgg_posts as posts
INNER JOIN wp_u8gwgg_postmeta as postmeta on posts.ID = postmeta.post_id
WHERE posts.post_type = 'product' 
  AND posts.post_status = 'publish'
GROUP BY posts.ID
ORDER BY posts.ID

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。