创建category
表:
create table category
(
categoryId int not null
primary key,
categoryName varchar(50) null
);
原始数据:
data:image/s3,"s3://crabby-images/5c69d/5c69de751d2e150d35580181e2015225fd22d70d" alt=""
创建product
表:
create table product
(
productId int auto_increment
primary key,
productName varchar(50) null,
categoryId int null,
price int null,
constraint product_category_categoryId_fk
foreign key (categoryId) references category (categoryId)
);
create index product_category_categoryId_fk
on product (categoryId);
原始数据:
data:image/s3,"s3://crabby-images/ab9c5/ab9c5b077f58f842e6250abe7ee0edb533f8f7b6" alt=""
只写join
:
select * from `product` join category
data:image/s3,"s3://crabby-images/9eebd/9eebd3eeae61d6c1507c1de6ca477a2babdecad0" alt=""
只写join
是做了笛卡尔积,4*2=8,每个product都拼上两种category
真正想要的是categoryId相等的情况
select * from `product` join category on product.categoryId = category.categoryId
data:image/s3,"s3://crabby-images/27811/2781113528de16e0ef312ee288200a898b6765c5" alt=""
注意:没有nike
的记录,因为没有对应的categoryId
如果想把没有对应categoryId
的产品也显示出来,用left join
(左外连接)
select * from `product` left join category on product.categoryId = category.categoryId
data:image/s3,"s3://crabby-images/96400/96400a0cd7ce7b18ce46836ad310cd3841a18f3a" alt=""
也就是product
中categoryId
为null
的产品会被显示
小插曲:mysql5.7.5以上版本group by查询问题解决:
group by 报错解决
select * from product left join category c on product.categoryId = c.categoryId group by product.categoryId;
data:image/s3,"s3://crabby-images/20239/20239f3db4bfaabd3e834a6e5ff168a1246aef3e" alt=""
select product.categoryId,categoryName, count(*) from product left join category c on product.categoryId = c.categoryId group by product.categoryId
data:image/s3,"s3://crabby-images/c69e8/c69e893b6e3e8ca84f085ce3cc034b10c014a9cc" alt=""
选择根据categoryName分类后的最便宜的产品:
select product.categoryId,categoryName, MIN(price) from product left join category c on product.categoryId = c.categoryId group by product.categoryId
data:image/s3,"s3://crabby-images/c020c/c020cc3a15e3a1c5cc0fb4dcdc6a8db34f19a397" alt=""
把nike对应的categoryId设置为1后,想要得到最便宜产品的名字:
select product.categoryId,categoryName,productName, MIN(price) from product left join category c on product.categoryId = c.categoryId group by product.categoryId
data:image/s3,"s3://crabby-images/f6e83/f6e837284dc587526b1a77cc9c40ac0b18d4d277" alt=""
正确写法是使用子查询:
select * from product join (
select product.categoryId,categoryName, MIN(price) from product left join category c
on product.categoryId = c.categoryId group by product.categoryId
) as cat_min
on product.categoryId = cat_min.categoryId
data:image/s3,"s3://crabby-images/71e85/71e85c93a67dc5e5ea8be46185ab8e343cca1690" alt=""
select * from product join (
select product.categoryId,categoryName, MIN(price) as min_price from product left join category c
on product.categoryId = c.categoryId group by product.categoryId,categoryName
) as cat_min
on product.categoryId = cat_min.categoryId
where product.price = cat_min.min_price
data:image/s3,"s3://crabby-images/186ff/186ffe46f3c4a96d6d7fca0048b7bee04bb034b5" alt=""
优化:
select product.productName,cat_min.categoryName,cat_min.min_price from product join (
select product.categoryId,categoryName, MIN(price) as min_price from product left join category c
on product.categoryId = c.categoryId group by product.categoryId,categoryName
) as cat_min
on product.categoryId = cat_min.categoryId
where product.price = cat_min.min_price
data:image/s3,"s3://crabby-images/b9733/b9733ae45f5dcbc08295419c015c921d75dc1bd5" alt=""
网友评论