一直以来,还是Oracle用的比较多。 MySQL的分组,看着总是有些奇怪。 实验如下,创建初始化数据: create table sod_artist_catego
一直以来,还是oracle用的比较多。
mysql的分组,看着总是有些奇怪。
实验如下,创建初始化数据:
create table sod_artist_category_relation(
songid int ,
CategoryID int
);
insert into sod_artist_category_relation values (1,1),(1,2),(1,3),(2,3),(2,4),(3,1);
用 php + mysql 驱动的在线商城系统,我们的目标为中国的中小企业及个人提供最简洁,最安全,最高效的在线商城解决方案,使用了自建的会员积分折扣功能,不同的会员组有不同的折扣,让您的商店吸引更多的后续客户。 系统自动加分处理功能,自动处理会员等级,免去人工处理的工作量,让您的商店运作起来更方便省事 采用了自建的直接模板技术,免去了模板解析时间,提高了代码利用效率 独立开发的购物车系统,使用最

假设这是歌曲和歌曲分类的映射表,,一个歌曲可以有多个分类,比如"华语"和"男歌星"。
MySQL可以进行如下分组:
select songid,CategoryID,count(*) from sod_artist_category_relation group by songid;

他除了正常的分组,还可以带上其他的字段,如果这些额外的字段有重复,则选择第一个数据。
这个特性很方便,如果使用Oracle,可以使用相关子查询模拟,
select songid,
(select min(CategoryID) from sod_artist_category_relation where songid=t1.songid) CategoryID,
count(*) from sod_artist_category_relation t1 group by songid;

本文永久更新链接地址:










