最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

mysql - Get posts from category with custom query

programmeradmin1浏览0评论

I've got a custom sql query to get latest posts from specific category (ID = 62). It looks like this:

SELECT p.ID,
       u.display_name AS author,
       post_date_gmt,
       post_title,
       p.post_author AS author_id,
       rel.term_taxonomy_id,

  (SELECT guid
   FROM wp_BOMEGAposts
   WHERE id = m.meta_value) AS image,

  (SELECT term_taxonomy_id
   FROM wp_BOMEGAterm_relationships
   WHERE object_id = p.ID) AS categories
FROM wp_BOMEGAposts p
LEFT JOIN wp_BOMEGAusers u ON p.post_author = u.ID
LEFT JOIN wp_BOMEGApostmeta m ON p.ID = m.post_id
INNER JOIN wp_BOMEGAterm_relationships rel ON p.ID = rel.object_id
WHERE p.post_type = 'post'
  AND p.post_status = 'publish'
  AND m.meta_key = '_thumbnail_id'
  AND rel.term_taxonomy_id IN (62)
ORDER BY p.post_date DESC
LIMIT 1
OFFSET 0

This posts have multiple categories and I want to get them. So I wrote a sub-query to revice them. But I'm getting an error:

#1242 - Subquery returns more than 1 row

How can I fix this?

I've got a custom sql query to get latest posts from specific category (ID = 62). It looks like this:

SELECT p.ID,
       u.display_name AS author,
       post_date_gmt,
       post_title,
       p.post_author AS author_id,
       rel.term_taxonomy_id,

  (SELECT guid
   FROM wp_BOMEGAposts
   WHERE id = m.meta_value) AS image,

  (SELECT term_taxonomy_id
   FROM wp_BOMEGAterm_relationships
   WHERE object_id = p.ID) AS categories
FROM wp_BOMEGAposts p
LEFT JOIN wp_BOMEGAusers u ON p.post_author = u.ID
LEFT JOIN wp_BOMEGApostmeta m ON p.ID = m.post_id
INNER JOIN wp_BOMEGAterm_relationships rel ON p.ID = rel.object_id
WHERE p.post_type = 'post'
  AND p.post_status = 'publish'
  AND m.meta_key = '_thumbnail_id'
  AND rel.term_taxonomy_id IN (62)
ORDER BY p.post_date DESC
LIMIT 1
OFFSET 0

This posts have multiple categories and I want to get them. So I wrote a sub-query to revice them. But I'm getting an error:

#1242 - Subquery returns more than 1 row

How can I fix this?

Share Improve this question asked Jun 15, 2020 at 14:17 Daniel KoczułaDaniel Koczuła 1032 bronze badges
Add a comment  | 

1 Answer 1

Reset to default 1

It looks like this is the new part of this query causing the problem, is that right?

(SELECT term_taxonomy_id
FROM wp_BOMEGAterm_relationships
WHERE object_id = p.ID) AS categories

If so the error message is clear: a sub-select in this query should only return one row. If it returns more than one row it doesn't know how to mash all those many rows into the one row of the rest of the query.

So you need to find a way to join all the rows of this subquery together into one row, and the SQL command GROUP_CONCAT will do that

You want to make the subquery something like:

(SELECT GROUP_CONCAT(term_taxonomy_id)
FROM wp_BOMEGAterm_relationships
WHERE object_id = p.ID) AS categories

If there were more than one term_taxonomy_id's to be returned, they'll then be returned in a single row comma delimited, like:

10,50,100

So you'll need to figure out what you want to do with those.

发布评论

评论列表(0)

  1. 暂无评论