Full连接和自连接查询

来源:网络整理

假想以下场景:某一电商网站想要对站内产品做层级分类,一个类别下面有若干子类,子类下面也会有别的子类。例如数码产品这个类别下面有笔记本,台式机,智能手机等;笔记本,台式机,智能手机又可以按照品牌分类;品牌又可以按照价格分类,等等。也许这些分类会达到一个很深的层次,呈现一种树状的结构。那么这些数据要怎么在数据库中表示呢?我们可以在数据库中创建两个字段来存储id和类别名称,使用第三个字段存储类别的子类或者父类的id,最后通过自连接去查询想要的结果。

自连接查询其实等同于连接查询,需要两张表,只不过它的左表(父表)和右表(子表)都是自己。做自连接查询的时候,是自己和自己连接,分别给父表和子表取两个不同的别名,然后附上连接条件。看下面的例子:

1. 创建数据表:

注:cate_name表示分类的名称,parent_id表示父类的id。

2. 插入数据:

查询结果:

3. 查询所有分类以及分类的父类:假想有左右两张表(都是tdb_cates),左表是子表,右表是父表;查询子表的id,子表的cate_name,父表的cate_name;连接条件是子表的parent_id等于父表的id。

查询结果:

Full连接

SQL FULL JOIN结合的左,右外连接的结果。

连接表将包含的所有记录来自两个表,并使用NULL值作为两侧缺失匹配结果

语法

FULL JOIN的基本语法如下:

在这里,给定的条件可能是根据您的需要给定任意的表达式。

例子:

考虑下面的两个表中,(a)CUSTOMERS表如下:

现在,让我们使用FULL JOIN在这两个表如下:

如果你的数据库不支持FULL JOIN,如MySQL不支持FULL JOIN,那么可以使用UNION ALL子句,将两个JOIN为如下:

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180612G034WM00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。

扫码关注云+社区

领取腾讯云代金券