终于知道SQL中多表查询中逗号是隐式的内连接了,inner join关键字是显示的内连接。。。

困惑了许久,今天终于知道from后面两个表用“,”分隔原来是隐式的内连接。
内连接分为显示的内连接和隐式的内连接,显示的内连接有inner join关键字,隐式的内连接用逗号分隔两个数据库表。隐式的内连接没有on关键字表示的条件,条件的表示只能用where,用inner join关键字查询出的结果为连接条件和查询条件筛选后的笛卡尔积。
一、隐式内连接。使用大家比较熟悉的员工表emp和部门表dept举个栗子吧

select * from emp,dept where emp.deptno=dept.deptno

不能使用on的链接条件,只能用where作为条件进行筛选。
二。显示的内连接

select * from emp inner join dept on emp.deptno = dept.deptno where 条件

内连接的结果是笛卡尔积,《数据库概论第五版》给出了精准的定义还有例子。
两个分别为n列和m列的数据库表R和S的笛卡尔积是一个(n+m)列的元组(理解为属性)的集合。元组的前n列是数据库表R的列,后m列是数据库表S的列。若R有K1个元组(即K1条数据),S有K2个元组,则数据库表R和S的迪卡尔积有K1乘K2条数据。就是R表中的每一条数据对应S表中的每一条数据,这样组成的结果集

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值