数据库中的FROM与连接的关系

  • 连接是从两个关系中的笛卡尔积中选取满足一定条件的元组
  • 等值连接是从广义笛卡尔积中选取属性值相等的那些元组
  • 广义笛卡尔积:列相加,行相乘
  • 若在等值连接中把目标列中的重复的属性列去掉则为自然连接,所以说,连接生成的虚拟表一般会导致列数增加
  • inner join(等值连接) 只返回两个表中联结字段相等的行的记录
  • 不加where条件会出现笛卡尔积,这种结果没有实际意义
  • 直接from多表关联 加了where条件以后,只有两个表相匹配的行才能在结果集中出现
  • 从结果上看一样。但是从实现上看,多个from是迪卡尔集,再筛选,效率是O(n^2),很差。
    join是先做hash,再匹配,效率是O(logN),很好。所以推荐前者。

posted on 2020-12-27 12:44  兔哥DB  阅读(388)  评论(0编辑  收藏  举报

导航