成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁(yè) > 網(wǎng)站建設(shè) > 建站知識(shí) > mysql group by分組取每組前幾條記錄加order by排序

mysql group by分組取每組前幾條記錄加order by排序

POST TIME:2017-11-13 00:19

mysql分組取每組前幾條記錄(排名) 附group by與order by的研究,需要的朋友可以參考下

--按某一字段分組取最大(小)值所在行的數(shù)據(jù)

復(fù)制代碼代碼如下:


/*
數(shù)據(jù)如下:
name val memo
a 2 a2(a的第二個(gè)值)
a 1 a1--a的第一個(gè)值
a 3 a3:a的第三個(gè)值
b 1 b1--b的第一個(gè)值
b 3 b3:b的第三個(gè)值
b 2 b2b2b2b2
b 4 b4b4
b 5 b5b5b5b5b5
*/


--創(chuàng)建表并插入數(shù)據(jù):

復(fù)制代碼代碼如下:


create table tb(name varchar(10),val int,memo varchar(20))
insert into tb values('a', 2, 'a2(a的第二個(gè)值)')
insert into tb values('a', 1, 'a1--a的第一個(gè)值')
insert into tb values('a', 3, 'a3:a的第三個(gè)值')
insert into tb values('b', 1, 'b1--b的第一個(gè)值')
insert into tb values('b', 3, 'b3:b的第三個(gè)值')
insert into tb values('b', 2, 'b2b2b2b2')
insert into tb values('b', 4, 'b4b4')
insert into tb values('b', 5, 'b5b5b5b5b5')
go


--一、按name分組取val最大的值所在行的數(shù)據(jù)。

復(fù)制代碼代碼如下:


--方法1:select a.* from tb a where val = (select max(val) from tb where name = a.name) order by a.name
--方法2:
select a.* from tb a where not exists(select 1 from tb where name = a.name and val > a.val)
--方法3:
select a.* from tb a,(select name,max(val) val from tb group by name) b where a.name = b.name and a.val = b.val order by a.name
--方法4:
select a.* from tb a inner join (select name , max(val) val from tb group by name) b on a.name = b.name and a.val = b.val order by a.name
--方法5
select a.* from tb a where 1 > (select count(*) from tb where name = a.name and val > a.val ) order by a.name
/*
name val memo
---------- ----------- --------------------
a 3 a3:a的第三個(gè)值
b 5 b5b5b5b5b5
*/


本人推薦使用1,3,4,結(jié)果顯示1,3,4效率相同,2,5效率差些,不過(guò)我3,4效率相同毫無(wú)疑問(wèn),1就不一樣了,想不搞了。
--二、按name分組取val最小的值所在行的數(shù)據(jù)。

復(fù)制代碼代碼如下:


--方法1:select a.* from tb a where val = (select min(val) from tb where name = a.name) order by a.name
--方法2:
select a.* from tb a where not exists(select 1 from tb where name = a.name and val < a.val)
--方法3:
select a.* from tb a,(select name,min(val) val from tb group by name) b where a.name = b.name and a.val = b.val order by a.name
--方法4:
select a.* from tb a inner join (select name , min(val) val from tb group by name) b on a.name = b.name and a.val = b.val order by a.name
--方法5
select a.* from tb a where 1 > (select count(*) from tb where name = a.name and val < a.val) order by a.name
/*
name val memo
---------- ----------- --------------------
a 1 a1--a的第一個(gè)值
b 1 b1--b的第一個(gè)值
*/


--三、按name分組取第一次出現(xiàn)的行所在的數(shù)據(jù)。

復(fù)制代碼代碼如下:


select a.* from tb a where val = (select top 1 val from tb where name = a.name) order by a.name
/*
name val memo
---------- ----------- --------------------
a 2 a2(a的第二個(gè)值)
b 1 b1--b的第一個(gè)值
*/


--四、按name分組隨機(jī)取一條數(shù)據(jù)。

復(fù)制代碼代碼如下:


select a.* from tb a where val = (select top 1 val from tb where name = a.name order by newid()) order by a.name/*
name val memo
---------- ----------- --------------------
a 1 a1--a的第一個(gè)值
b 5 b5b5b5b5b5
*/


--五、按name分組取最小的兩個(gè)(N個(gè))val

復(fù)制代碼代碼如下:


select a.* from tb a where 2 > (select count(*) from tb where name = a.name and val < a.val ) order by a.name,a.valselect a.* from tb a where val in (select top 2 val from tb where name=a.name order by val) order by a.name,a.val
select a.* from tb a where exists (select count(*) from tb where name = a.name and val < a.val having Count(*) < 2) order by a.name
/*
name val memo
---------- ----------- --------------------
a 1 a1--a的第一個(gè)值
a 2 a2(a的第二個(gè)值)
b 1 b1--b的第一個(gè)值
b 2 b2b2b2b2
*/


--六、按name分組取最大的兩個(gè)(N個(gè))val

復(fù)制代碼代碼如下:


select a.* from tb a where 2 > (select count(*) from tb where name = a.name and val > a.val ) order by a.name,a.val
select a.* from tb a where val in (select top 2 val from tb where name=a.name order by val desc) order by a.name,a.val
select a.* from tb a where exists (select count(*) from tb where name = a.name and val > a.val having Count(*) < 2) order by a.name
/*
name val memo
---------- ----------- --------------------
a 2 a2(a的第二個(gè)值)
a 3 a3:a的第三個(gè)值
b 4 b4b4
b 5 b5b5b5b5b5
*/


--七,假如整行數(shù)據(jù)有重復(fù),所有的列都相同(例如下表中的第5,6兩行數(shù)據(jù)完全相同)。
按name分組取最大的兩個(gè)(N個(gè))val

復(fù)制代碼代碼如下:


/*
數(shù)據(jù)如下:
name val memo
a 2 a2(a的第二個(gè)值)
a 1 a1--a的第一個(gè)值
a 1 a1--a的第一個(gè)值
a 3 a3:a的第三個(gè)值
a 3 a3:a的第三個(gè)值
b 1 b1--b的第一個(gè)值
b 3 b3:b的第三個(gè)值
b 2 b2b2b2b2
b 4 b4b4
b 5 b5b5b5b5b5
*/


附:mysql “group by ”與"order by"的研究

這兩天讓一個(gè)數(shù)據(jù)查詢難了。主要是對(duì)group by 理解的不夠深入。才出現(xiàn)這樣的情況

這種需求,我想很多人都遇到過(guò)。下面是我模擬我的內(nèi)容表


我現(xiàn)在需要取出每個(gè)分類(lèi)中最新的內(nèi)容

select * from test group by category_id order by `date`


結(jié)果如下


明顯。這不是我想要的數(shù)據(jù),原因是msyql已經(jīng)的執(zhí)行順序是

引用


寫(xiě)的順序:select ... from... where.... group by... having... order by..
執(zhí)行順序:from... where...group by... having.... select ... order by...


所以在order by拿到的結(jié)果里已經(jīng)是分組的完的最后結(jié)果。
由from到where的結(jié)果如下的內(nèi)容。


到group by時(shí)就得到了根據(jù)category_id分出來(lái)的多個(gè)小組



到了select的時(shí)候,只從上面的每個(gè)組里取第一條信息結(jié)果會(huì)如下


即使order by也只是從上面的結(jié)果里進(jìn)行排序。并不是每個(gè)分類(lèi)的最新信息。
回到我的目的上 --分類(lèi)中最新的信息
根據(jù)上面的分析,group by到select時(shí)只取到分組里的第一條信息。有兩個(gè)解決方法
1,where+group by(對(duì)小組進(jìn)行排序)
2,從form返回的數(shù)據(jù)下手腳(即用子查詢)
由where+group by的解決方法
對(duì)group by里的小組進(jìn)行排序的函數(shù)我只查到group_concat()可以進(jìn)行排序,但group_concat的作用是將小組里的字段里的值進(jìn)行串聯(lián)起來(lái)。

select group_concat(id order by `date` desc) from `test` group by category_id



再改進(jìn)一下

select * from `test` where id in(select SUBSTRING_INDEX(group_concat(id order by `date` desc),',',1) from `test` group by category_id ) order by `date` desc



子查詢解決方案

select * from (select * from `test` order by `date` desc) `temp`group by category_id order by `date` desc


相關(guān)文章推薦:

1.mysql查看最大連接數(shù)和修改mysql數(shù)據(jù)庫(kù)最大連接數(shù)方法

2.php+mysql實(shí)現(xiàn)無(wú)限級(jí)分類(lèi)



上一篇:mysql查看最大連接數(shù)和修改mysql數(shù)據(jù)庫(kù)最大連接數(shù)

下一篇:手機(jī)app開(kāi)發(fā)與調(diào)試相關(guān)知識(shí)和經(jīng)驗(yàn)

收縮
  • 微信客服
  • 微信二維碼
  • 電話咨詢

  • 400-1100-266
成年人在线看| 日本道在线观看| 少妇人妻精品一区二区三区| 亚洲国产精品一区二区www在线| 蜜桃一区二区三区在线观看| 精品视频在线看| 亚洲最大成人在线| 偷拍精品精品一区二区三区| 人妻 丝袜美腿 中文字幕| 国产伦精品一区三区精东| 亚洲精品午夜级久久久久| 91精品久久久久久久久久久久久久| 俺去啦俺在线观看| 免费激情小视频| 国产成人在线免费| 亚洲精品一二三**| 国产小视频在线播放| 欧美成人免费视频a| 亚洲精品国产精品乱码不卡| 欧洲熟妇的性久久久久久| 91精品久久久久久久99蜜桃| 国产欧美日韩精品a在线观看| 中文字幕在线播放| 亚在线播放中文视频| 国产亚洲精品久久久久久青梅| 欧美喷潮久久久xxxxx| 成人丝袜视频网| jizzzz日本| 综合区小说区图片区在线一区| 性欧美69式xxxxx| 欧洲精品在线视频| 国产一区二区三区欧美| 欧美性受黑人性爽| 日韩av免费观影| 国产精品视频一区二区免费不卡| 国产一区二区三区在线免费观看| 国产精品你懂的在线欣赏| 亚洲无人区一区| 婷婷综合激情网| 久久精精品视频| 国产一区激情在线| 亚洲一区日本| 国产精品免费无码| 国产人妻人伦精品| 国产在线激情视频| 91最新地址在线播放| 亚洲男女av一区二区| 天堂中文在线视频| 欧美性极品xxxx娇小| 欧美福利在线视频| 国精品人伦一区二区三区蜜桃| 欧美三级在线播放| 欧美日韩国产va另类| 亚洲午夜av电影| 大胆亚洲人体视频| 91久久夜色精品国产九色| 日韩在线一二三区| 黄网视频在线观看| 高清在线一区| 天堂中文在线资| 污污的视频在线免费观看| 久久99久久人婷婷精品综合| 国产一区一区| 久久精品视频在线观看| 成人春色激情网| 成人毛片一区二区三区| www.亚洲欧美| 欧美精美视频| 免费男女羞羞的视频网站中文子暮| 天堂在线www天堂中文在线| 美女永久在线网站| 好吊日免费视频| 不卡影院一区二区| 亚洲欧美自拍视频| 欧美白人做受xxxx视频| 久久久久无码国产精品一区| 国产一区二区色噜噜| 亚洲欧美国产77777| 自拍偷拍21p| 91嫩草|国产丨精品入口| 欧美一二三视频| 成人免费视频网站入口::| 亚洲综合激情五月| 超碰在线免费看| 精品五月天久久| 国产精品尤物视频| 免费成人黄色| 日韩精品一区二区三区在线| 草草浮力影院| 亚洲第一精品久久忘忧草社区| 91精品国产乱码久久久久久久| 午夜精品福利一区二区三区av| 欧美一区二三区| 亚洲高清不卡在线| 四虎国产精品永久在线| 粉嫩久久99精品久久久久久夜| 日本视频在线播放| 狠狠色丁香婷婷综合久久片| 成人免费网站在线观看视频| 999国产精品亚洲77777| av在线看片| 国产一区喷水| 亚洲一区二区三区四区在线| 欧美日韩中文字幕日韩欧美| 欧美黑人又粗又大又爽免费| 无圣光视频在线观看| 黄色片大全在线观看| 国产成人精品一区二区免费看京| 国产成人在线视频| 久久在线观看免费| 1024国产精品| 欧美最大成人综合网| 欧美日韩综合视频| 亚洲欧美日韩国产| 中文字幕 欧美激情| 亚洲小视频网站| 国产精品日韩精品欧美在线| 99re66热这里只有精品4| 亚洲激情亚洲| 久久精品www人人爽人人| 中文字幕av在线播放| zzjj国产精品一区二区| 国产成人av无码精品| 国产在线观看福利| 黄色亚洲网站| 亚洲精品国产系列| 粗大的内捧猛烈进出在线视频| 风间由美久久久| 在线免费观看黄色片| 香蕉视频一区二区| 国产又大又长又粗| 亚洲欧美文学| 男男做爰猛烈叫床爽爽小说| 性做久久久久久免费观看| 狠狠色henhense| 欧美男女性生活在线直播观看| 在线看的毛片| 久久久一区二区三区捆绑**| 高清欧美电影在线| 国产精品久久久久久久| 制服丝袜在线第一页| 国产免费av观看| 成人黄在线观看| bt天堂新版中文在线地址| 国产精品久久久久久免费免熟| 精品一区二区三区蜜桃在线| 怡红院av在线| 99国产精品免费网站| 好看的av在线不卡观看| 成人激情电影一区二区| 免费在线看成人av| 欧美三级日本三级少妇99| 亚洲高清不卡在线| 色呦呦一区二区| 亚洲v国产v在线观看| 999久久久精品国产| 亚洲成在人线在线播放| 国产福利久久| 麻豆传媒一区二区三区| 男男gay免费网站| 国产精品视频一二三| 久久99蜜桃精品久久久久小说| 特级毛片在线观看| 欧美精品日日操| 影音先锋日韩精品| 国产精品稀缺呦系列在线| 黄色工厂这里只有精品| 久久蜜桃一区二区| 手机看片国产精品| 色黄视频免费看| a天堂中文在线官网在线| 国产精品欧美一区二区三区奶水| 免费人成短视频在线观看网站| 999国产精品永久免费视频app| 国产深喉视频一区二区| 日本a级片电影一区二区| 亚洲美女福利视频网站| 日韩最新av| 久久老司机精品视频| 欧美久久一二三四区| 在线免费观看亚洲视频| 国产小视频免费在线观看| 欧美xxxxhdvideosex| 国产精品三区在线观看| 欧美图片一区二区| 黄色片免费网址| 蜜桃特黄a∨片免费观看| 椎名由奈jux491在线播放| 日本护士做爰视频| 国产99免费视频| 欧美激情精品久久久久久蜜臀| 国产成人精品一区二三区在线观看| 六月婷婷综合| 免费在线观看av的网站| 色老板在线视频一区二区| 久久久久久国产精品一区| 中文字幕在线观看日本| 日本最新不卡在线| 国产主播喷水一区二区| 午夜精品一区二区三区电影天堂| 波多野结衣小视频| 日韩免费av片在线观看| 国产亚洲精品午夜高清影院| 香蕉加勒比综合久久| 精品亚洲成人| 成人9ⅰ免费影视网站| 欧美极品欧美精品欧美图片| 日本亚洲欧美天堂免费| 亚洲熟妇国产熟妇肥婆| 欧美影院午夜播放| 麻豆av电影| 亚洲欧美高清视频| 一本到av在线| 日本a级片电影一区二区| 久久久久久国产免费a片| 国产精品亚洲综合色区韩国| 日本天码aⅴ片在线电影网站| 国产精彩视频在线观看| 日本精品一区二区三区在线播放| av色影在线看免费| 亚洲国产第一区| 91视频在线看| 99国产揄拍国产精品| 亚洲人成网站999久久久综合| 色婷婷综合成人| 成人欧美视频在线观看播放| 91在线视频播放地址| 超碰成人免费在线| 久久人妻一区二区| 2024最新电影在线免费观看| 超碰超碰超碰超碰超碰| 麻豆一区二区在线观看| 亚洲视频播放| 久久精品色综合| 极品av少妇一区二区| 黄色亚洲精品| 麻豆专区一区二区三区四区五区| 成年人小视频在线观看| 97在线视频国产| 99热这里是精品| 成人网在线免费看| 精品网站www| 国产成人丝袜美腿| 本田岬高潮一区二区三区| 久久国产精品久久久久久小说| 国产精品素人一区二区| 国产日韩欧美日韩大片| 欧美午夜视频在线观看| 中文字幕有码在线观看| 欧美午夜大胆人体| 粉嫩嫩av羞羞动漫久久久| 成人在线视频网| 欧美日韩国产一中文字不卡| 日韩欧美一区二区不卡| 日本vs亚洲vs韩国一区三区二区| 丰满爆乳一区二区三区| 伊人久久婷婷色综合98网| 中文字幕精品在线播放| 亚洲欧美天堂网| 亚洲精品在线免费| 国产suv精品一区二区883| 北条麻妃在线一区二区免费播放| av大片在线免费观看| 亚洲久草视频| 国产精品高潮呻吟久久av黑人| 亚洲精品福利资源站| 综合国产第二页| 国产一区二区三区四区视频| 国产乱码精品一区二区亚洲| 精精国产xxx在线视频app| 国产成人无码一区二区在线观看| 国产亚洲精品美女久久久久久久久久| 性一交一黄一片| 久久99热这里只有精品| 麻豆理论在线观看| 亚洲一级理论片| 在线视频你懂| 亚洲一区二区三区四区在线免费观看| 黄色网在线播放| 欧美国产日韩一区二区在线观看| 国产a级黄色大片| 日韩欧美一区二区三区久久婷婷| 少妇av一区二区三区| 川上优av中文字幕一区二区| 欧美黑人疯狂性受xxxxx喷水| 亚洲第一区av| 亚洲一区二区精品3399| 99久久久久久久久久| 亚洲精品乱码久久久久久日本蜜臀| 在线永久免费观看黄网站| 精品国产一区二区三区不卡蜜臂| 亚洲黑人在线| 国产女主播在线写真| 精品亚洲综合| 日本网址在线观看| 很黄很a的视频| 黑巨人与欧美精品一区| 久久久久国产精品免费免费搜索| 国产精品91一区二区| 国产区精品在线观看| 大型av综合网站| 国产在线88av| 亚欧美一区二区三区| 黑人巨大精品欧美一区二区一视频| 国产精品扒开腿做爽爽爽视频软件| 亚洲色欲色欲www在线观看| 精品无人区一区二区三区竹菊| 中文字幕一区二区三区人妻不卡| 狠狠色噜噜狠狠狠狠色吗综合| 麻豆精品传媒视频| 成人国产精品免费观看视频| 国产精品视频一区二区三区不卡| 日韩国产欧美| 136福利第一导航国产在线| 国产伦一区二区三区| 欧美福利专区| av一区二区三区免费观看| 国产大片中文字幕| 日韩视频在线播放| 久久超级碰视频| 一区二区三区不卡视频| 欧美在线观看视频免费| 高清av一区二区| 中文在线不卡视频| 欧美一区国产二区| 日韩三级视频在线观看| 欧美国产激情一区二区三区蜜月| 久久久久免费|