MySQL 查詢以基於相應列名稱按字母順序對最高三個值進行選擇排序
為此,您可以使用 ORDER BY 子句。讓我們先建立一個表 -
mysql> create table DemoTable ( Name varchar(40), Score int ); Query OK, 0 rows affected (1.11 sec)
使用 insert 命令在表中插入一些記錄 -
mysql> insert into DemoTable values('Chris',45); Query OK, 1 row affected (0.26 sec) mysql> insert into DemoTable values('Bob',98); Query OK, 1 row affected (0.10 sec) mysql> insert into DemoTable values('David',78); Query OK, 1 row affected (0.17 sec) mysql> insert into DemoTable values('Mike',96); Query OK, 1 row affected (0.14 sec) mysql> insert into DemoTable values('Carol',43); Query OK, 1 row affected (0.20 sec)
使用 select 語句從表中顯示所有記錄 -
mysql> select *from DemoTable;
這將產生以下輸出 -
+-------+-------+ | Name | Score | +-------+-------+ | Chris | 45 | | Bob | 98 | | David | 78 | | Mike | 96 | | Carol | 43 | +-------+-------+ 5 rows in set (0.00 sec)
以下是從 “Score” 列中選擇最高三個值並按字母順序對相應的 “Name” 列進行排序的查詢 -
mysql> select *from (select Name,Score from DemoTable order by Score desc,Name asc limit 3) tbl order by Name;
這將產生以下輸出 -
+-------+-------+ | Name | Score | +-------+-------+ | Bob | 98 | | David | 78 | | Mike | 96 | +-------+-------+ 3 rows in set (0.03 sec)
廣告