Сложный порядок по пункту? - PullRequest
2 голосов
/ 26 марта 2010

Мне нужно сделать то, что для меня является продвинутым. У меня есть две таблицы:

Table: Fruit  

fruitid | received | basketid  
  1       20100310   2  
  2       20091205   3  
  3       20100220   1  
  4       20091129   2  

Table: Basket  
id | name  
1    Big Discounts  
2    Premium Fruit  
3    Standard Produce  

Я даже не уверен, что могу прямо сказать, как я хочу сортировать (что, вероятно, является большой причиной того, что я не могу написать код для этого, смеется).

Я делаю запрос на соединение и мне нужно отсортировать, чтобы все было организовано по корзинке. Сначала идет корзинка с самой ранней датой получения фруктов. Затем идут другие строки с той же самой корзиной по дате asc, затем корзина со следующей самой ранней датой фруктов. Получаются другие строки с той же самой корзинкой и так далее.

Таким образом, результат будет выглядеть следующим образом:

Fruitid | Received  |   Basket  
   4      20091129      Premuim Fruit  
   1      20100310      Premuim Fruit  
   2      20091205      Standard Produce  
   3      20100220      Big Discounts  

Есть идеи, как этого добиться в одном исполнении?

Ответы [ 2 ]

2 голосов
/ 26 марта 2010

попробуйте это (код установки таблицы сервера SQL, но запрос должен работать в любой базе данных)

DECLARE @Fruit table (fruitid int, received int, basketid int)
INSERT @Fruit VALUES(1,       20100310,   2 )
INSERT @Fruit VALUES(2,       20091205,   3 )
INSERT @Fruit VALUES(3,       20100220,   1 )
INSERT @Fruit VALUES(4,       20091129,   2 )

DECLARE @Basket table (id int,basket varchar(20))
INSERT @Basket VALUES (1,    'Big Discounts'  )
INSERT @Basket VALUES (2,    'Premium Fruit'  )
INSERT @Basket VALUES (3,    'Standard Produce')


SELECT
    f.Fruitid ,f.received,b.basket  
    FROM @Fruit f
      INNER JOIN (SELECT
                      basketid, MIN(received) AS received
                      FROM @Fruit
                      GROUP BY basketid  
                 ) o ON f.basketid = o.basketid
      INNER JOIN @Basket b ON o.basketid=b.id
    ORDER BY o.received

OUTPUT

Fruitid     received    basket
----------- ----------- --------------------
4           20091129    Premium Fruit
1           20100310    Premium Fruit
2           20091205    Standard Produce
3           20100220    Big Discounts

(4 row(s) affected)
2 голосов
/ 26 марта 2010
SELECT  f.fruitid, f.received, ba.name AS basket
FROM    Fruit f
JOIN    (
        SELECT  basketid, MIN(received) AS mr
        FROM    fruit
        GROUP BY
                basketid  
        ) b
ON      f.basketid = b.basketid
JOIN    basket ba
ON      ba.id = f.basketid
ORDER BY
        b.mr, f.basketid, f.received
...