群裡有童鞋問,想要根據使用者分組,以該使用者的下單時間為降序,提取所有使用者的第二個訂單資訊。
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