《视图更新与关系数据库理论》——1.6 小结

1.6 小结

抛砖引玉到此就要告一段落了。我们所用到的这个例子非常简单,从中得出的结论也是显而易见的。而其实我是想通过这个例子引出下面的理念,就是根据实际的定义把视图看作与特定的表相附生的基表,这对于整体考虑如何解决视图更新的问题是很有建设性的。我认为它不仅具有建设性,而且是一种“逻辑上正确”的方法。[8]总体思路如下。

1.视图定义表达式包含了某些特定的约束。例如,视图LS(“London suppliers”)的视图定义表达式表明了LS等同于表S中CITY值为London的约束。

2.这种约束反过来表明了特定的补偿性操作(如那些为了避免违反完整性约束,而需要在用户自行请求的更新之外进行的操作)。举例来说,正如前面讲到的,表S、LS和NLS的约束就代表相应的级联删除和级联插入。

这里我要强调第2点——这点很重要,就是在某些状况下,补偿性操作可以由相关视图的定义表达式决定。换句话说,这样的操作不需要显式指定,也不需要给已经超负荷的DBA[9]增加工作负担。对于这个问题和其他在本章中引出的问题,我都会在后面的章节进行更详细的探讨。

最后,如果你像大多数人一样跳过了前言直接开始阅读第1章,那么现在是时候翻回去阅读前言了,这对你继续阅读下面的章节会很有帮助。前言包含了本书的整体结构,同时还阐明了将要在下面的章节使用的重要的技术性假设,因此需要你对它们有所了解。  

[1] 我在本章这个介绍性的章节使用SQL和SQL风格的语法是因为大家都对它比较熟悉,尽管它并不是我喜欢的风格,并且(更重要的是)事实上它可能会让这个抛砖引玉的例子更不容易解释清楚。

[2] 在本书中我都使用未经认证的“键”这个词来表示候选键,而不是一个特定的主键。实际上,在第2章中就会介绍到的“Tutorial D”对于主键和其他键在语法上并没有区别。但是,由于大家使用习惯的原因,我在图例中都使用双下画线来表示主键属性,如图1.1所示。

[3] 我在前言的时候就声明过,在本书中我将使用《SQL and Relational Theory》作为简写来引用我的另一本书《SQL and Relational Theory: How to Write Accurate SQL Code》(第2版,奥莱利出版,2012)。

[4] 正是由于这个原因,更真实一点版本的视图LS很可能会去掉CITY属性。在这里我选择不这样做,是为了让这个例子更简单易懂。

[5] 曾经有一位审阅者问我,为什么我在这里要选择“补偿性操作”这个词。当时我自己认为这个答案很明显,不过为了以防万一,我还是在这里做一个说明:之所以我把这些操作称为“补偿性”的,是因为它们都会导致第2次更新发生来补偿第1次的效果(当然是大体上来讲)。

[6] 级联删除通常都被认为是使用一个特定的外键约束,但是补偿性操作的概念其实更加通用,并且适合很多种约束。

[7] 我假设有些用户“可能”会被允许进行这样的操作,如果他或她在操作被拒绝的时候能够接受错误信息显示的只是“因为系统就是这么说的”,而没有更进一步的解释。关于这一点的进一步讨论详见第4章。

[8]  在此感谢David McGoveran,他在多年前启发我思考这些问题。

[9]  DBA=database administrator,也就是数据库管理员。

本文仅用于学习和交流目的,不代表异步社区观点。非商业转载请注明作译者、出处,并保留本文的原始链接。

时间: 2024-09-20 10:59:44

《视图更新与关系数据库理论》——1.6 小结的相关文章

《Python极客项目编程 》——1.6 小结

1.6 小结 在这个项目中,我们开发了一个程序,分析了iTunes播放列表.在这个过程中,我们学习了一些有用的Python结构.在接下来的项目中,你将基于这里介绍的一些基础知识,探索各种有趣的主题,深入地研究Python.

《Python极客项目编程 》——2.6 小结

2.6 小结 在这个项目中,我们学习了如何创建万花尺那样的曲线.我们还学习了如何调整输入参数,来生成各种不同的曲线,并在屏幕上产生动画.我希望你喜欢创造这些螺线(在第13章你会惊喜地发现,可以学到如何将螺线投影到墙上).

《Python极客项目编程 》——第2章 万花尺 2.1 参数方程

第2章 万花尺 我们可以用万花尺玩具(如图2-1所示)来绘制数学曲线.这种玩具由两个不同尺寸的塑料齿轮组成,一大一小.小的齿轮有几个孔.把钢笔或铅笔放入一个孔,然后在较大齿轮(内部有齿)内旋转里面的小齿轮,保持笔与外轮接触,可以画出无数复杂而奇妙的对称图案. 在这个项目中,我们将用Python来创建动画,像万花尺一样绘制曲线.我们的spiro.py程序将用Python和参数方程来描述程序的万花尺齿轮的运动,并绘制曲线(我称之为螺线).我们可以将完成的画图保存为PNG图像文件,并用命令行选项来指定

《Python极客项目编程 》——第一部分 热身运动 第1章 解析iTunes播放列表 1.1 iTunes播放列表文件剖析

第一部分 热身运动 "在初学者的头脑中有很多可能性, 在专家的头脑中,可能性很少." --铃木俊隆 第1章 解析iTunes播放列表 我们的Python探险始于一个简单的项目,该项目在iTunes播放列表文件中查找重复的乐曲音轨,并绘制各种统计数据,如音轨长度和评分.你可以从查看iTunes播放列表格式开始,然后学习如何用Python提取这些文件的信息.为了绘制这些数据,要用到matplotlib库. 在这个项目中,我们将学习以下主题: XML和属性列表(p-list)文件: Pyth

《Python极客项目编程 》——2.3 代码

2.3 代码 首先,定义类Sipro,来绘制这些曲线.我们会用这个类一次画一条曲线(利用draw()方法),并利用一个定时器和update()方法,产生一组随机螺线的动画.为了绘制Spiro对象并产生动画,我们将使用SpiroAnimator类. 要查看完整的项目代码,请直接跳到2.4节. 2.3.1 Spiro构造函数 下面是Spiro构造函数: # a class that draws a Spirograph class Spiro: # constructor def __init__(

《Python极客项目编程 》——2.2 所需模块

2.2 所需模块 我们将利用下面的模块创建螺线: turtle模块用于绘图: pillow,这是Python图像库(PIL)的一个分支,用于保存螺线图像.

《Python极客项目编程 》——1.2 所需模块

1.2 所需模块 在这个项目中,我们用内置模块plistlib来读取播放列表文件.我们还用matplotlib库来绘图,用numpy的数组来存储数据.

《Python极客项目编程 》——1.5 运行程序

1.5 运行程序 下面是该程序的运行示例: $ python playlist.py --common test-data/maya.xml test-data/rating.xml 下面是输出: 5 common tracks found. Track names written to common.txt. $ cat common.txt God Shuffled His Feet Rubric Floe Stairway To Heaven Pi's Lullaby moksha:pla

《Python极客项目编程 》——2.7 实验

2.7 实验 下面有一些方法可以进一步尝试螺线. 1.现在你已知道如何画圆,请写一个程序来绘制随机的对数螺线.找到参数形式的对数螺线方程,然后用它来绘制螺线. 2.你可能已经注意到,画曲线时,海龟光标总是朝右,但这不是海龟移动的方式!请调整海龟的方向,在绘制曲线时,让它朝向绘制的方向(提示:每步计算连续点之间的方向矢量,用turtle.setheading()方法来调整海龟的方向). 3.尝试用海龟绘制Koch snowflake(科赫雪花),它是利用递归(即调用自身的函数)的分形曲线.可以像这

《Python极客项目编程 》——1.7 实验

1.7 实验 下面有一些方法可以扩展这个程序. 1.发现重复音轨时,考虑了以音轨时长作为附加标准,来确定两个音轨是否相同.但寻找共同的音轨时,只用了音轨名称进行比较.在findCommonTracks()中,请结合音轨时长作为额外的检查. 2.在plotStats()方法中,用了matplotlib的hist()方法来计算和显示柱状图.请编写代码手动计算直方图,不用hist()方法显示.要将结果显示为条形图,请阅读matplotlib文档中条形图的部分. 3.有一些数学公式用于计算相关系数,测量