国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

關于MYSQL中每個用戶取1條記錄的三種寫法(group by xxx)

2020-01-18 23:34:18
字體:
來源:轉載
供稿:網友
今天以前的同學問我關于這方面的SQL語句,我特意記憶一下,畢竟這個也比較常見了
復制代碼 代碼如下:

select * from (select * from member_payment
                order by id desc) t group by member_id limit 10

第一種是先排序,然后group,這樣的話自然可以取到最適合的一條數據。
缺點很明顯:Using temporary; Using filesort
復制代碼 代碼如下:

select s.*
from (SELECT max(id) as id FROM `member_payment` group by `member_id` limit 10) t
left join `member_payment` as s on t.id=s.id

第二種是聯合查詢
復制代碼 代碼如下:

select * from `member_payment` where EXISTS (
 select `id` from (
  SELECT max(`id`) as id FROM `member_payment` group by `member_id` limit 10) t
 where t.`id`=`member_payment`.`id`
)

第三種是子查詢
竊以為第二種效率最高
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 鄢陵县| 连南| 栖霞市| 马公市| 西青区| 乌海市| 北碚区| 正蓝旗| 台北县| 纳雍县| 阿荣旗| 绥宁县| 同心县| 漳州市| 大邑县| 绿春县| 略阳县| 工布江达县| 清新县| 项城市| 龙井市| 交城县| 安国市| 新泰市| 盘山县| 武宣县| 寿阳县| 大田县| 衡南县| 东方市| 长丰县| 团风县| 普宁市| 望奎县| 鄂伦春自治旗| 海伦市| 新安县| 和硕县| 常山县| 政和县| 全南县|