mysqlパケットソートの実装


グループには、ユーザーグループに基づいて、そのユーザーの注文時間を降順にして、すべてのユーザーの2番目の注文情報を抽出したいという子供靴の質問があります.
これはグループソートに属し、Oracleでは内蔵関数が実現されますが、mysqlでは卵が痛いです.
参考にする方法を提供します
CREATE TABLE user_orders (orders_id INT UNSIGNED NOT NULL,
user_id INT UNSIGNED NOT NULL,
add_time INT UNSIGNED NOT NULL,
PRIMARY KEY(orders_id),
KEY(user_id),
KEY(add_time)
)ENGINE=INNODB DEFAULT CHARSET utf8 COMMENT 'mysql         ';

INSERT INTO `user_orders` (`orders_id`, `user_id`, `add_time`) VALUES('1','1','1');
INSERT INTO `user_orders` (`orders_id`, `user_id`, `add_time`) VALUES('2','1','2');
INSERT INTO `user_orders` (`orders_id`, `user_id`, `add_time`) VALUES('3','1','3');
INSERT INTO `user_orders` (`orders_id`, `user_id`, `add_time`) VALUES('4','2','1');
INSERT INTO `user_orders` (`orders_id`, `user_id`, `add_time`) VALUES('5','2','2');
INSERT INTO `user_orders` (`orders_id`, `user_id`, `add_time`) VALUES('6','2','3');
INSERT INTO `user_orders` (`orders_id`, `user_id`, `add_time`) VALUES('7','3','1');
INSERT INTO `user_orders` (`orders_id`, `user_id`, `add_time`) VALUES('8','3','2');
INSERT INTO `user_orders` (`orders_id`, `user_id`, `add_time`) VALUES('9','3','3');

SELECT orders_id,user_id,add_time,rank FROM (
SELECT  @rownum:=@rownum+1 AS rownum,#   
    IF(@x=uo.user_id,@rank:=@rank+1,@rank:=1) rank,#    ,  @x  user_id,   @x    , @rank  1
    @x:=uo.user_id, #    @x,@x     , rank     ,  ,rank    ,@x null      user_id  
    orders_id,user_id,add_time 
FROM  
    user_orders  uo,
    (SELECT @rownum:=0,@rank:=0) init #       
ORDER BY user_id ASC, add_time DESC
)result
WHERE rank=2

ポイント:キーは@xがどのように値を割り当てるかです.@xの付与を知ると,rank(順位)の由来がすぐに分かる.