MySQL高级分组排序
Posted 程芸
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL高级分组排序相关的知识,希望对你有一定的参考价值。
想要根据用户分组,以该用户的下单时间为降序,提取所有用户的第二个订单信息。
这属于分组排序,在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`