MYSQL数据库MySQL中distinct与group by语句的一些比较及用法讲解
《MYSQL数据库MySQL中distinct与group by语句的一些比较及用法讲解》要点: 在数据表中记录了用户验证时使用的书目,现在想取出所有书目,用DISTINCT和group by都取到了我想要的结果,但我发现返回结果排列不同,distinct会按数据存放顺序一条条显示,而group by会做个排序(一般是ASC). 上面来看MySQL中distinct及group by的一些用法分享.MYSQL教程 CREATE TABLE `student` ( `name` varchar(20) NOT NULL DEFAULT '',`age` int(10) DEFAULT '0' ) ENGINE=InnoDB DEFAULT CHARSET=latin1 1.测试一 select * from student; ?? a 5 a 5 c 0 用distinct过滤失落两列都相同的记录 select distinct name,age from student; 返回 a 5 c 0 2.测试二 select * from student; c 2 c 5 select distinct name,age from student; 返回如下,阐明distinct后面有多于一列的字段时,只有每列的值完全相同才过滤 c 2 c 5 3.测试三 select * from student; name age height c 2 123 c 2 456 b 20 222 group by按两列同时分组 select name,age,sum(height) from student group by name,age; b 20 222 c 2 579 group by按两列同时分组,同时在后面加上having的前提 select name,sum(height) as n from student group by name,age having n > 500;? 返回 4.测试四 select songname,sengerid,count(sengerid) as n from t_song group by songname,sengerid having n > 1 ORDER BY n DESC,songid ASC limit 10; 未知 8738 40 共同渡过 1432 24 风继续吹 1432 23 倩女幽魂 1432 23 无心睡眠 1432 23 罗百吉超嗨派对持续组曲 780 19 拒绝再玩 1432 19 风再起时 1432 18 每天爱你多一些 1480 18 千言万语 1794 18代码如下: select songname,songid ASC limit 5;MYSQL教程 未知 8738 40 共同渡过 1432 24 风继续吹 1432 23 倩女幽魂 1432 23 无心睡眠 1432 23 经过以上两个测试可以看出,如果sql语句中含有limit,limit是对用group by进行分组,并进行相关计算以后的limit操作,而不是对limit后面的指定记录数进行分组,从n那一列的数据每一行的值都年夜于10就可以看出来.MYSQL教程 5.测试五 select count(distinct(songid)) from feedback; select count(distinct songid) from feedback; 6.测试六 select feedback_id,songid,songname,max(time) as new_time from feedback group by songid order by new_time desc; 7.Sql语句中where,group by,order by及limit的次序 where xxx,group by xxx,order by xxx,limit xxx 8.关于group by与count的问题 select feedback_id,max(time) as new_time from feedback group by songid order by new_time desc; 代码以下: MySQL Query Error: SELECT COUNT(*) FROM feedback GROUP BY songid ORDER BY new_time DESC Error Info:Unknown column 'new_time' in 'order clause'MYSQL教程 《MYSQL数据库MySQL中distinct与group by语句的一些比较及用法讲解》是否对您有启发,欢迎查看更多与《MYSQL数据库MySQL中distinct与group by语句的一些比较及用法讲解》相关教程,学精学透。编程之家PHP学院为您提供精彩教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |