SQL的联结

  1、什么是关系表

  • 关系表的设计就是要把信息分解成多个表,一类数据一个表,各表通过某些共同的值互相关联。这些共同的值都是各个表中的唯一标识,即主键。
  • 关系数据库的可伸缩性远比非关系数据库要好。
    • 可伸缩性(scale):能够适应不断增加的工作量而不失败。
    • 设计良好的数据库或应用程序称为可伸缩性好(scale well)。

  2、什么是联结

  • 简单来说,联结是一种机制,用来在一条SELECT语句中关联表。
  • 联结在运行时关联表中正确的行。
  • 联结不是物理实体,它在实际的数据库表中并不存在,它在执行查询期间一直存在。
  • 联结中的表的关系是在运行中构造的。
  • 么有联结条件的表关系返回的结果为笛卡尔积,检索出的行的数目将是各个表中行数的乘积。此类联结,也被称作为叉联结(cross join)。

  3、等值联结(equijoin)

  等值联结,是基于两个表之间的相等测试。看示例,理解的更明白:

SELECT column1, column2, column3
FROM table_a, table_b
WHERE table_a.some_column = table_b.some_column;

  等值联结中若要过滤的话,是通过WHERE子句来实现。

  4、内联结(inner join)

  等值联结,也被称作为内联结,只是语法稍微有点不同,请看示例:

SELECT column1, column2, column3
FROM table_a INNER JOIN table_b
ON table_a.some_column = table_b.some_column;

  在内联结的语法中是通过INNER JOIN关键字来联结数据表的,通过ON子句来过滤条件的。

  5、联结多个表

  • SQL不限制一条SELECT语句中可以联结的表的数目。创建联结表的基本规则也是相同的,首先列出所有表,然后定义表之间的关系。
  • DBMS在运行时关联指定的每个表,以处理联结。这种处理可能非常耗费资源,所以不要联结不必要的表。联结的表越多,性能下降的越厉害。
  • 虽然SQL本身不限制每个联结约束中表的数目,但实际上许多DBMS都有限制。

  

SQL的联结

上一篇:HDU 5694 BD String 递归暴力


下一篇:【delphi】多线程同步之Semaphore