国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

查詢分組后每個分組的前幾條記錄

來源:懂視網 責編:小采 時間:2020-11-09 13:36:38
文檔

查詢分組后每個分組的前幾條記錄

查詢分組后每個分組的前幾條記錄:在MySQL使用中,經常需要查詢每個分組的前幾條記錄(查詢分組后每一個組的前幾項),下面寫了個簡單的例子說明下SQL的寫法。簡單的表設計如下,要求每個班總分排名最前的前兩條數據。 測試表語句如下: create table test(id int unsigned no
推薦度:
導讀查詢分組后每個分組的前幾條記錄:在MySQL使用中,經常需要查詢每個分組的前幾條記錄(查詢分組后每一個組的前幾項),下面寫了個簡單的例子說明下SQL的寫法。簡單的表設計如下,要求每個班總分排名最前的前兩條數據。 測試表語句如下: create table test(id int unsigned no

在MySQL使用中,經常需要查詢每個分組的前幾條記錄(查詢分組后每一個組的前幾項),下面寫了個簡單的例子說明下SQL的寫法。簡單的表設計如下,要求每個班總分排名最前的前兩條數據。 測試表語句如下: create table test(id int unsigned not null auto_inc

在MySQL使用中,經常需要查詢每個分組的前幾條記錄(查詢分組后每一個組的前幾項),下面寫了個簡單的例子說明下SQL的寫法。簡單的表設計如下,要求每個班總分排名最前的前兩條數據。

測試表語句如下:

create table test(id int unsigned not null auto_increment primary key,name varchar(10),class varchar(20),score varchar(20));
insert into test(name, class, score) values ('gonn', '6(1)', '299');
insert into test(name, class, score) values ('yyun', '6(1)', '259');
insert into test(name, class, score) values ('lin', '6(1)', '289');
insert into test(name, class, score) values ('mei', '6(1)', '277');
insert into test(name, class, score) values ('xj', '6(2)', '287');
insert into test(name, class, score) values ('zhl', '6(2)', '277');
insert into test(name, class, score) values ('lwjs', '6(2)', '257');
insert into test(name, class, score) values ('lulu', '6(2)', '265');

運行以上SQL,得到的表結構如下:

mysql> SELECT * FROM test;
+----+------+-------+-------+
| id | name | class | score |
+----+------+-------+-------+
| 1 | gonn | 6(1) | 299 |
| 2 | yyun | 6(1) | 259 |
| 3 | lin | 6(1) | 289 |
| 4 | mei | 6(1) | 277 |
| 5 | xj | 6(2) | 287 |
| 6 | zhl | 6(2) | 277 |
| 7 | lwjs | 6(2) | 257 |
| 8 | lulu | 6(2) | 265 |
+----+------+-------+-------+
8 rows in set

方法一

mysql> SELECT a.id,a.name,a.class,a.score
FROM test a LEFT JOIN test b on a.class = b.class and a.score < b.score
GROUP BY a.id,a.name,a.class,a.score
HAVING count(b.id) < 2
ORDER BY a.class,a.score DESC;
+----+------+-------+-------+
| id | name | class | score |
+----+------+-------+-------+
| 1 | gonn | 6(1) | 299 |
| 3 | lin | 6(1) | 289 |
| 5 | xj | 6(2) | 287 |
| 6 | zhl | 6(2) | 277 |
+----+------+-------+-------+
4 rows in set

方法二

mysql> SELECT * FROM test a
WHERE 2 >(SELECT count(*) FROM test WHERE class = a.class and score>a.score)
ORDER BY a.class,a.score DESC;
+----+------+-------+-------+
| id | name | class | score |
+----+------+-------+-------+
| 1 | gonn | 6(1) | 299 |
| 3 | lin | 6(1) | 289 |
| 5 | xj | 6(2) | 287 |
| 6 | zhl | 6(2) | 277 |
+----+------+-------+-------+
4 rows in set

這里列出了多種SQL語句的實現方法,有些是MySQL特有的(Limit, 其它數據庫可根據實際更改,比如oracle的rownum,MS SQL SERVER 的 top,..),有時是SQL標準支持的。但效率上和應用的場合或許不同。具體應用時可根據實際表中的記錄情況,索引情況進行選擇。

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

查詢分組后每個分組的前幾條記錄

查詢分組后每個分組的前幾條記錄:在MySQL使用中,經常需要查詢每個分組的前幾條記錄(查詢分組后每一個組的前幾項),下面寫了個簡單的例子說明下SQL的寫法。簡單的表設計如下,要求每個班總分排名最前的前兩條數據。 測試表語句如下: create table test(id int unsigned no
推薦度:
標簽: 查詢 記錄 分組
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 久久一次 | er久99久热只有精品国产 | 国产中文在线 | 国产乱来视频 | 国产成人一区 | 在线播放国产一区 | 国产第十页 | 国产91精品一区二区视色 | 日本另类αv欧美另类aⅴ | 日本欧美一区二区三区不卡视频 | 国产欧美在线观看一区二区 | 中文字幕日韩欧美 | 国产一区欧美二区 | 性色a v 一区 | 成人久久久精品乱码一区二区三区 | 手机国产精品一区二区 | 91网红福利精品区一区二 | 国产精品伦一区二区三级视频 | 国产国拍亚洲精品午夜不卡17 | 欧美综合图区 | 精品国产乱码一区二区三区麻豆 | 国产欧美视频在线观看 | 国产成人精品999在线 | 国产综合精品久久久久成人影 | 亚洲欧美日韩在线一区 | 92国产精品 | 国产精品高清久久久久久久 | 91精品国产91久久久久久 | 日本a级片免费观看 | 欧美a在线观看 | 最近免费中文字幕大全免费版视频 | 国内精品91久久久久 | 欧美成人中文字幕在线视频 | 国产欧美久久一区二区 | 欧美日韩精品一区二区视频在线观看 | 国产偷窥在线观看 | 国产免费网 | 亚洲高清色 | 亚洲欧美激情另类 | 一区二区三区四区视频 | 亚洲精品视频在线播放 |