【数据库】到底什么是关系?

计算机学习者经常会用到诸如Sqlserver Mysql Orcal 等“关系型”数据库。

问题一:那么,到底什么是“关系”呢?

首先,我们来看以下三组数据

                  

注:A1,A2表示具体的某个人,比如张三,李四

我们用数学集合的形式对其进行表达,得到三个集合

  男人: D1 { A1,A2,A3 }
  女人: D2 { B1,B2,B3 }
  小孩: D3 { C1,C2,C3 }

  我们称 D1 D2 D3 为 “域”

接来下,我们将这三个集合取笛卡尔积(如果不懂的话,请自行查阅,简单理解就是从三个集合中元素里各取一个,能够形成的所有组合)

  D1*D2*D3=? 直观来说,结果显示在下表内   

  

显然,该结果整体并没有什么真实含义,单纯的作为一些数据的组合,于是,我们便通过“某一关系”将表中含有意义的部分选择出来,如下图:

  

通过“家庭”这种“关系”我们便得到了上表,其中意义显而易见且通俗易懂,正是我们人类,数据库管理人员、开发者等所需要的。这个表再关系型数据库中被称为“关系”。

其中,丈夫,妻子,子女统称为属性名,家庭作为关系名或表名。

由此表,可得到一些解释:

  1.元组:一行完整的数据,如A1 B1 C1

  2.关系:属性名+表名+数据

  3.关系模式:属性名+表名

通过对比可看出关系与关系模式的异同,同一关系模式下可能存在多种关系,比如随着时间的推移,人口的更变,表中数据发生了变化,所以关系模式是稳定的,关系是不稳定的。

问题二:那么,我们为什么要通过求笛卡尔积这种思路来理解这部分的学习呢?计算机与数学到底是什么关系呢?

有人说,“数学是上帝的语言”。我们作为开发者,虽然我们最常使用的是高级语言,诸如C++ JAVA C#,他们代码的书写方式,语法,编程范式,编程思想都更加接近于人类的思考

纵观计算机语言发展历史,语言的目的在于沟通,作为一端,计算机本质上只是一门工具,语言的发展本质上是应该更好的服务于开发者,使其更容易专注于业务,而非机器逻辑。

但是,为了让机器更加高效的服务,我们不得不在一些事上有所侧重,一些底层系统更是如此。

显然,计算机并不能直接理解我们的话,他直接理解的可能只有01,只有逻辑运算,只有线性运算(只有加法与乘法构成的运算),因此,我们为了让计算机能够听懂并且好用,我们需要定义“数学模型”!

看到这里,很多问题迎刃而解,为什么我们要用笛卡尔积,为什么我们要取他的子集,甚至为什么我们要在每个列上取一个新的名字并且标注他的类型(如,学生表中的年龄(int))。

归根结底,我们在寻求一种来自于数学的精准定义,计算机能够理解并执行的数学模型! 模型如下:

关系模式  R(A1:D1,A2:D2,...,An:Dn);

举个例子,家庭(丈夫:男人,妻子:女人,孩子:儿童);

家庭作为关系名,丈夫作为属性,:后面跟着的男人就是丈夫所属的“域”(你可以理解为,领域或类型,比如1、2、3的域可以是整数)。

那么,为什么既然有域了,我还要有属性名呢?

因为,实际业务中,很多属性都来源于同一个域,我们可以有效地区分,例如:身高和体重都来源于浮点型域,姓名和地址都来源于字符串类型域。

至此,什么是关系,什么是表,在数据库使用中,我们为什么要这么定义表,从根本上都是有原因的,相信,你已经明白了。再见~

原文地址:https://www.cnblogs.com/labixiaohei/p/12105453.html

时间: 2024-11-08 10:42:51

【数据库】到底什么是关系?的相关文章

微服务?数据库?它们之间到底是啥关系?

过去几年来,"微服务架构"这个术语持续火热,它描述了一种将软件应用程序设计为可独立部署的服务套件的特定方式.尽管这种架构风格没有确切的定义,但围绕业务能力,自动化部署,网点智能以及语言和数据的分散控制等方面存在着某些共同特征.简而言之,微服务架构是一种将单应用程序作为一套小型服务开发的方法,每种应用程序都在其自己的进程中运行,并与轻量级机制(通常是HTTP资源的API)进行通信.这些服务是围绕业务功能构建的,可以通过全自动部署机制进行独立部署.这些微服务的将集中化管理部分降到最少,同时

[转帖]JPA和Hibernate到底是什么关系???

JPA和Hibernate到底是什么关系??? https://www.cnblogs.com/mosoner/p/9494250.html (文章借用了其他几篇博客中的内容,因为是初学者,许多概念性的关系自己不能完全理解,就将大神的搬了过来,如有不当,可留言,本人自会妥善处理,谢谢) 在学习框架的过程中,发现学的东西很多,但是感觉他们之间的联系区别都不是很了解,知道JPA可以去实现持久化数据到数据库当中,Hibernate也有这样的功能,总以为他们之间是一种平级的关系,拥有同样的作用,是一种可

非关系型数据库中的「关系」实现

Knowledge Dependence:阅读文本前,你需要了解基本的关系型数据库与非关系型(NoSQL)数据库的概念和区别,以及 MongoDB(Mongoose)的简单实践. ? 这两三年来,伴随着大数据(Big Data)的空前火热,无论是在工程界还是科研界,非关系型数据库(NoSQL)都已经成为了一个热门话题. 相比于传统的关系型数据库,非关系型数据库天生从理念上就给数据存储提供了一种新的思路.而在实际应用中,它往往更轻巧灵活.扩展性高,并且更能胜任高性能.大数据量的场景. 值得一提的是

JS原型的问题Object和Function到底是什么关系

var F = function(){}; Objcert.prototype.a = function(){}; Function.prototype.b = function(){}; F 既能访问到a,也能访问到(Object 和 Function也同样,但是所有的实例只能访问到a):F是Object 和 Function 两个的实例,那么Object 和 Function 到底是什么关系? 下面是对Object 和 Function 的了解 F instanceof Object tru

内核与ramdisk到底是什么关系

转自:http://www.lupaworld.com/forum.php?mod=viewthread&tid=61425 原名:内核与ramdisk到底是什么关系? 个人Notes:       (1)有这个必要吗? --相当有!不然内核太大!不符"内核"原则.       (2)作用:"既要内核小,又要内核不带草",解决"先有鸡还是先有蛋的问题".       (3)解决该问题所依据的客观事实:ramdisk根文件系统也是由boot

Scaled Agile Framework (SAFe) 和产品管理间到底有什么关系 ?

SAFe 就是将 RUP (Rational Unfied Process), Lean, Scrum 给搅和在一起. SAFe 也许解决了大团队在制定版本计划与协作上的一些问题. 但我实在不明白,SAFe 和所谓的 "产品管理" 间到底有什么关系? SAFe  既没有最基础的 "价值特性识别实践",也没有 ALM (Application Lifecycle Management), 更没有 PLM (Product Lifecycle Management).

我们和搜索引擎到底是什么关系?!

我们和搜索引擎到底是什么关系?!理论上来讲,我们是独立的网站,搜索引擎也是,本身是没有什么关系的,你管不到我我也不会管你.但是,又因为搜索引擎的特殊功能,我们不得不去迎合它,除非你希望自己的网站只有自己看. 一.搜索引擎. 目前比较大的有Google.百度.雅虎.必应.360.搜搜等等.其中以谷歌和百度为主,大部分用户使用的是这两个搜索引擎.这也导致了市场一家独大的现状(谷歌以退出中国),虽然百度不会刻意的去控制排名和收录,但是规则始终是在它手上! 二.个人站点. 绝大部分的网站或者个人博客,都

数据库到底用不用外键

最近工作中用到powerdesigner ,前期需要通过powerdesigner生成表结构,后来由于负责人员不在,很多表结构的添加没有同步到powerdesigner,一个个核对表结构着实麻烦,于是想到到反向生成模型,但数据库没有外键关系导致生成的模型也没有外键.对项目中不用外键感到好奇于是问了相关人员原因,并简单了解了外键的特点和使用场景.为了进一步了解,在网上找了相关文章以下为转载的原文链接: http://www.cnblogs.com/pengxl/archive/2010/06/11

django之模型类、迁移和数据库表之间的关系

环境配置:ubuntu 16.04,Django 1.8.2,MySQL-python 1.2.5 目的是为了了解模型类的定义和其对应数据库里面表的关系 实测发现: 关于模型类和数据库里面的表关系,模型类里面定义的类属性是为了生成数据库里面的表结构使用的,类似mysql里面创建一个表. 一个模型类,对应着数据库里面的一个表. 一个类属性,对应着数据库表里面的一个字段 一个类属性的类型(如charfield),对应着数据库里面字段类型. 进入python manage.py shell运行的pyt