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`, `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(名次)的由來。
既然是分組排序,那當然是按組內來編號,每組當然得有一個不變的列,要不然按什麼group by呢?抓住這個特點自然就理解了rank的含義,還有一個點要注意就是group by的時候要有兩個排序的條件,要不然組內不穩定
相關文章
- Java利用Comparator實現分組排序Java排序
- mysql使用group by實現組內排序實戰MySql排序
- Mysql 分組排序的sql寫法MySql排序
- order by改分組排序排序
- MYSQL——分組MySql
- ForkJoin和氣泡排序組合實現的歸併排序排序
- 一句話實現MySQL庫中的重疊分組MySql
- MySQL 分組排序後 → 如何取前N條或倒數N條MySql排序
- MySQL主從分離實現MySql
- MySQL 是如何實現資料的排序的?MySql排序
- 一句話實現MySQL庫中的按連續等值分組MySql
- FPGA排序模組與verilog實現【含原始碼!!!】FPGA排序原始碼
- ProxySQL實現MySQL讀寫分離MySql
- 一句話實現MySQL庫中的有序列舉條件分組MySql
- MySQL怎麼實現主從同步和Django實現MySQL讀寫分離MySql主從同步Django
- 順序表實現二分排序排序
- pt-archiver實現MySQL定期分表HiveMySql
- mysql 無限級分類實現思路MySql
- mysql group_concat 實現把分組欄位寫成一行的方法MySql
- MongoDB 如何實現巢狀子文件分組MongoDB巢狀
- JAVA將快速將列表分組並排序鍵Java排序
- 資料庫之DQL排序&分組&函式資料庫排序函式
- ShardingSphere + Mysql,實現分庫分表、讀寫分離,並整合 SpringBootMySqlSpring Boot
- vxe-table 實現表格資料分組,按指定欄位資料分組
- php實現 歸併排序,快速排序PHP排序
- docker+atlas+mysql實現讀寫分離DockerMySql
- Kubernetes 中實現 MySQL 的讀寫分離MySql
- 用listagg函式分組實現列轉行函式
- java實現快速排序Java排序
- Swift實現快速排序Swift排序
- js 實現堆排序JS排序
- GO 實現快速排序Go排序
- 快速排序(java實現)排序Java
- 快速排序 java實現排序Java
- 你們要的MyCat實現MySQL分庫分表來了MySql
- javascript: 帶分組資料的Table表頭排序JavaScript排序
- Go實現氣泡排序和快速排序Go排序
- ProxySQL實現Mysql讀寫分離 - 部署手冊MySql