笛卡尔积现象

2.3、当两张表进行连接查询时,没有任何条件的限制会发生什么现象?

  案例:查询每个员工所在部门名称?

    select * from emp;

    select ename,dname from emp,dept;

  当两张表进行连接查询,没有任何条件限制时,最终查询结果条数,是两张表条数的乘积

2.4、怎么避免笛卡尔积现象?

  连接时加条件,满足这个条件的记录筛选出来

  select ename,dname from emp,dept where emp.deptno = dept.deptno;

  注意:最终查询的结果条数是14,匹配过程中,匹配的次数减少了吗? 次数没减少还是56次,只不过有条件了

    通过笛卡尔积现象,表的连接次数越多效率越低,应减少表的连接次数

  select emp.ename,dept.dname from emp,dept where emp.deptno = dep.deptno; //这样效率高

  //再起个别名

  select e.ename,d.dname from emp e,dept d where e.deptno = d.deptno;//这样起别名效率更高(重要)(SQL92语法)

  

posted @   doremi429  阅读(104)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示