Mysql 使用商城表完成对商品信息的多表查询

### 使用商城表完成对商品信息的多表查询

#### 需求分析:

在商城项目中,我的订单中包含很多信息.打开订单需要去查询表

#### 技术分析:

#### 多表查询

- 交叉连接查询  笛卡尔积

- 内连接查询

- 左外连接

- 右外连接  

注:inner和outer关键字可省可不省.

- 交叉连接查询  笛卡尔积
SELECT * FROM product;
SELECT * FROM category;

笛卡尔积 ,查出来是两张表的乘积 ,查出来的结果没有意义
SELECT * FROM product,category;

--过滤出有意义的数据
SELECT * FROM product,category WHERE cno=cid;

SELECT * FROM product AS p,category AS c WHERE p.cno=c.cid;[使用as关键字]
SELECT * FROM product p,category c WHERE p.cno=c.cid;[不使用as关键字]


--数据准备
INSERT INTO product VALUES(NULL,'耐克',10,NULL);

- 内连接查询
-- 隐式内链接
  SELECT * FROM product p,category c WHERE p.cno=c.cid;
-- 显示内链接
  SELECT * FROM product p INNER JOIN category c ON p.cno=c.cid;[使用inner关键字]
   SELECT * FROM product p JOIN category c ON p.cno=c.cid;[不使用inner关键字]
-- 区别:
	隐式内链接: 在查询出结果的基础上去做的WHERE条件过滤
	显示内链接: 带着条件去查询结果, 执行效率要高

- 左外连接
  左外连接,会将左表中的所有数据都查询出来, 如果右表中没有对应的数据,用NULL代替
  SELECT * FROM product p LEFT OUTER JOIN category c ON p.cno=c.cid;[使用outer关键字]
  SELECT * FROM product p LEFT JOIN category c ON p.cno=c.cid;[不使用outer关键字]

- 准备工作
  INSERT INTO category VALUES(10,'电脑办公','电脑品牌都在这');
- 右外连接: 会将右表所有数据都查询出来, 如果左表没有对应数据的话, 用NULL代替
  
  SELECT * FROM product p RIGHT OUTER JOIN category c ON p.cno=c.cid;[使用outer关键字]
  SELECT * FROM product p RIGHT JOIN category c ON p.cno=c.cid;[不使用outer关键字]

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值