0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

关系型数据库最难的地方,就是建模

电子工程师 来源:lp 2019-04-04 14:29 次阅读

关系型数据库最难的地方,就是建模(model)。

错综复杂的数据,需要建立模型,才能储存在数据库。所谓"模型"就是两样东西:实体(entity)+ 关系(relationship)。

实体指的是那些实际的对象,带有自己的属性,可以理解成一组相关属性的容器。关系就是实体之间的联系,通常可以分成"一对一"、"一对多"和"多对多"等类型。

在关系型数据库里面,每个实体有自己的一张表(table),所有属性都是这张表的字段(field),表与表之间根据关联字段"连接"(join)在一起。所以,表的连接是关系型数据库的核心问题。

表的连接分成好几种类型。

内连接(inner join)

外连接(outer join)

左连接(left join)

右连接(right join)

全连接(full join)

以前,很多文章采用维恩图(两个圆的集合运算),解释不同连接的差异。

上周,我读到一篇文章,认为还有比维恩图更好的解释方式。我发现确实如此,换一个角度解释,更容易懂。

所谓"连接",就是两张表根据关联字段,组合成一个数据集。问题是,两张表的关联字段的值往往是不一致的,如果关联字段不匹配,怎么处理?比如,表 A 包含张三和李四,表 B 包含李四和王五,匹配的只有李四这一条记录。

很容易看出,一共有四种处理方法。

只返回两张表匹配的记录,这叫内连接(inner join)。

返回匹配的记录,以及表 A 多余的记录,这叫左连接(left join)。

返回匹配的记录,以及表 B 多余的记录,这叫右连接(right join)。

返回匹配的记录,以及表 A 和表 B 各自的多余记录,这叫全连接(full join)。

下图就是四种连接的图示。我觉得,这张图比维恩图更易懂,也更准确。

上图中,表 A 的记录是 123,表 B 的记录是 ABC,颜色表示匹配关系。返回结果中,如果另一张表没有匹配的记录,则用 null 填充。

这四种连接,又可以分成两大类:内连接(inner join)表示只包含匹配的记录,外连接(outer join)表示还包含不匹配的记录。所以,左连接、右连接、全连接都属于外连接。

这四种连接的 SQL 语句如下。

SELECT*FROMAINNERJOINBONA.book_id=B.book_id;SELECT*FROMALEFTJOINBONA.book_id=B.book_id;SELECT*FROMARIGHTJOINBONA.book_id=B.book_id;SELECT*FROMAFULLJOINBONA.book_id=B.book_id;

上面的 SQL 语句还可以加上where条件从句,对记录进行筛选,比如只返回表 A 里面不匹配表 B 的记录。

SELECT*FROMALEFTJOINBONA.book_id=B.book_idWHEREB.idISnull;

另一个例子,返回表 A 或表 B 所有不匹配的记录。

SELECT*FROMAFULLJOINBONA.book_id=B.book_idWHEREA.idISnullORB.idISnull;

此外,还存在一种特殊的连接,叫做"交叉连接"(cross join),指的是表 A 和表 B 不存在关联字段,这时表 A(共有 n 条记录)与表 B (共有 m 条记录)连接后,会产生一张包含 n x m 条记录的新表(见下图)。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • SQL
    SQL
    +关注

    关注

    1

    文章

    737

    浏览量

    43449
  • 数据库
    +关注

    关注

    7

    文章

    3584

    浏览量

    63346
  • 数据集
    +关注

    关注

    4

    文章

    1176

    浏览量

    24340

原文标题:数据库表连接的简单解释

文章出处:【微信号:DBDevs,微信公众号:数据分析与开发】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    在LABVIEW中实现对数据库表格的操作

    设计的ODBC标准只能访问关系数据库,对非关系数据库则无能为力。为解决这个问题,Micros
    发表于 06-29 21:28

    数据库连接

    在利用 LabVIEW数据库工具包操作数据库之前,需要先连接数据库,这就像操作文件之前,先要打开文件一样。在这里我们利用UDL连接数据库。Microsoft设计的ODBC标准只能访问
    发表于 06-29 21:29

    建立与数据库的连接

    在利用 LabVIEW数据库工具包操作数据库之前,需要先连接数据库,这就像操作文件之前,先要打开文件一样。在这里我们利用UDL连接数据库。Microsoft设计的ODBC标准只能访问
    发表于 07-01 21:24

    Android如何使用Db4o数据库

    数据库的出现是为了更好的适合面向对象方式开发应用程序,因为传统的关系数据库与OO模 具有“阻抗不匹配”问题,目前广被接受的方案是使用OR
    发表于 05-24 07:32

    浅析对象数据库和NoSQL

    一个数据库的持久性整体规划通常都是不成套的。各种ORM(对象关系映射)工具都能更容易地进行对象和数据结构之间的转换,但没有一个是完美的。这就是通常所说的“ORM Impedance M
    发表于 05-27 06:36

    使用NoSQL数据库的原因

    阻抗失衡 关系模型和内存中的数据结构不匹配 采用更为方便的数据交互方式提升开发效率待处理的数据量很大 数据量超过
    发表于 05-27 06:43

    对象和数据库的天然阻抗

    :如果你使用对象语言,如Java/.NET/Ruby On Rails等,那么就必须坚持OO思想和方法,从程序中杜绝关系数据库对软件的影响,将关系数据库只看成是活动对象的“冬眠”(英文Hibernate)地方,这也
    发表于 05-30 06:56

    关系数据库与非关系数据库的区别浅析

    关系数据库的一个劣势就是 阻抗失谐(impedance mismatch):关系模型和内存中的数据
    发表于 06-03 06:03

    Hbase分布式非关系数据库安装部署步骤

    Hbase分布式非关系数据库安装与部署
    发表于 09-19 08:50

    MobiLink关系数据库同步系统是什么?

    和统一数据库保持同步,达到共享数据和保持数据一致性的目的。MobiLink是iAnywhere Solutions公司开发的基于会话的关系数据库同步系统,它支持远程
    发表于 10-09 06:09

    最新国产数据库排名

    金融领域应用案例;5.分布式、关系、云化及内存数据库占比统计。01 开篇在刚刚过去的一年也就是2019年是国产数据库崛起的元年,众多的国产
    发表于 07-28 08:06

    一款基于Java实现的小巧而强大的关系数据库

    H2 是一款基于 Java 实现的小巧而强大的关系数据库,支持嵌入式、客户端/服务器以及混合部署模式。H2 数据库适合嵌入小型应用程序、元数据
    发表于 10-27 06:12

    HarmonyOS数据库的相关资料下载

    1、HarmonyOS数据库篇之轻量级数据存储HarmonyOS中的数据库存储主要分为3种形式:1. 轻量级数据存储2. 关系
    发表于 03-28 11:13

    怎样使用Harmony Developer提供的关系数据库的相关API去读取sqlite文件内容呢

    Developer提供的关系数据库的相关API去读取之前放入的sqlite文件的内容,然后展示出来最后的效果如下:该demo中操作关系
    发表于 03-28 11:21

    HarmonyOS关系数据库和对象关系数据库的使用方法

    容易就上手的知识。本篇速成教程直接使用最精准和简短的文字,再配上讲解代码,让我们能在10分钟左右就能掌握最基本的数据库使用方法。数据库的三大要素:数据库、表、字段,接下来为大家介绍关系
    发表于 03-29 14:10