0

次のようなテーブルがあります。

content_id | contact_count
         1              23
         2               4
         3              89

テーブルの最後の 25 行から contact_count が最も高い content_id を選択したいと考えています。

次のようなさまざまなことを試しました。

select content_id from research_products_content
   where contact_count=(select max(contact_count)
        from research_products_content order by rating_total_id desc limit 25)
   order by rating_total_id desc limit 1
4

2 に答える 2

0

列番号は同じになるので UNION を使う

select content_id from research_products_content
   where contact_count=(select max(contact_count)
        from research_products_content order by rating_total_id desc limit 25)
UNION
select content_id from research_products_content
   where contact_count=(select max(contact_count)
        from research_products_content order by rating_total_id desc limit 1

途中でキャッシュを実装したい場合があります

于 2012-04-28T23:28:40.493 に答える
0

あなたの例では、結果(最大、単一行)が選択された後limit 25に適用されます。代わりにこれを試してください:

SELECT tmp.content_id FROM (
  SELECT *
  FROM research_products_content
  ORDER BY rating_total_id DESC
  LIMIT 25
  ) AS tmp
WHERE tmp.contact_count = (
  SELECT max(tmp2.contact_count)
  FROM (
    SELECT *
    FROM research_products_content
    ORDER BY rating_total_id DESC
    LIMIT 25
  ) AS tmp2
)
LIMIT 1
于 2012-04-28T23:30:48.377 に答える