dream890110 2015-03-19 14:24
浏览 14
已采纳

SELECT *在MAX和第二个MAX id之间的列WHERE另一列等于某个输入

I have a table called orders with (a.o.) columns sid and q1_requested_by. The sid column contains a unique id number, incrementing with every new input.

Every now and then there is an input in column q1_requested_by with the value ORDERS PROCESSED.

I want to select everything from the table which falls in between the latest ÒRDERS PROCESSED input and the latest but one ORDERS PROCESSED input.

I've tried the following, which doesn't work. It selects nothing.

SELECT * FROM orders 
WHERE sid < (SELECT max(sid) FROM orders
             WHERE q1_requested_by = 'ORDERS PROCESSED')
  AND sid > (SELECT TOP 2 sid FROM orders
             WHERE q1_requested_by = 'ORDERS PROCESSED'
             ORDER BY sid DESC)
ORDER BY sid DESC

How could I solve this?

  • 写回答

3条回答 默认 最新

  • duangang2825 2015-03-19 14:36
    关注

    First, you would use MySQL constructs:

    SELECT o.*
    FROM orders o
    WHERE o.sid < (SELECT max(sid)
                   FROM orders
                   WHERE q1_requested_by = 'ORDERS PROCESSED'
                  ) AND
          o.sid > (SELECT sid
                   FROM orders
                   WHERE q1_requested_by = 'ORDERS PROCESSED'
                   ORDER BY sid DESC
                   LIMIT 1, 1
                  )
    ORDER BY o.sid DESC
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥15 想问一下树莓派接上显示屏后出现如图所示画面,是什么问题导致的
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化