V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
huzhikuizainali
V2EX  ›  数据库

学习数据库需要怎样的离散数学基础?

  •  
  •   huzhikuizainali · 2021-07-14 14:16:15 +08:00 · 627 次点击
    这是一个创建于 1229 天前的主题,其中的信息可能已经有所发展或是发生改变。
    学习五种基本运算来合成除法的目的是什么?未来在数据库设计和使用过程中哪种场景会用到这些知识?目前的 DBMS 还不支持用 sql 语言直接实现除法操作?还需要使用者自己造轮子?

    sql 语言不已经是高级语言了?为什么讲数据库理论还需要用关系代数来描述很多例如“外并操作”这些关系数据库具体操作内容?当实际工作中遇到需要强行并两张表的问题时,直接用对应的 sql 语句实现不就好了。就好比日常用 excel 时张三遇到需要并两张表的问题,张三不需要知道关系代数的理论。它只需要知道 excel 通过 1 、2 、3 哪些步骤实现上述目标不就可以了?

    简而言之,并表这种很具体很形象的现实问题,为什么非要用关系代数这种抽象方法来描述??难道是要为造轮子做准备?

    《数据库系统基础教程》使用说明部分提到要求学过:数据结构,算法,离散数学。所以这本书中用到非常多离散数学的知识?需要先把离散数学的知识系统学一遍么?数据库中用到离散数学的内容主要是用于描述问题?还是为了像编程那用解决具体问题?
    zhangysh1995
        1
    zhangysh1995  
       2021-07-26 14:40:12 +08:00
    关系代数 /关系演算是描述关系型数据模型的基本理论,用途不仅限于解释如何使用 SQL,还包括 SQL 的理论基础(语义),SQL 与关系代数的等价,SQL 基于关系代数的优化等。
    这些知识只是使用并不需要知道,但是如果涉及到优化,debug 就需要了。
    SQL 发明是后于关系代数的。
    建议贴主重新看一下数据库系统概念等外国教材。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2728 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 43ms · UTC 11:14 · PVG 19:14 · LAX 03:14 · JFK 06:14
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.