




如果您无法下载资料,请参考说明:
1、部分资料下载需要金币,请确保您的账户上有足够的金币
2、已购买过的文档,再次下载不重复扣费
3、资料包下载后请先用软件解压,在使用对应软件打开
11招教你如何玩转数据库设计 11招教你如何玩转数据库设计 11招教你如何玩转数据库设计 11招教你如何玩转数据库设计 在日常工作中,当我们遇到海量数据时,如何从中挑选出自己想要的数据呢?是盲目的查找,还是寻求新的解决方案亦或是通过技巧来获取?开发者在设计一个数据表单时,往往会遵循HYPERLINK"http://youtu.be/wp0N1tYjEWc?hd=1”\t"_blank”三条常用形式,他们认为常规模式是设计的唯一途径.然而由于开发者一开始就抱有这种心态,使数据表单设计变得墨守成规,阻碍了它的创新. Rule1:弄清(OLTP或OLAP)应用的本质是什么? 当开始制作数据表单设计时,首先,要分析你设计的这个程序的本质是什么?是事务性还是分析性的?你会发现许多开发者会默认应用常规化规则,随后才考虑性能问题而不考虑应用的本质。 关于事务性和分析性,一起来看下两者区别. Transactional:这种应用,用户对CRUD较为感兴趣,即创建、读取、更新和删除记录。这种数据,官方名称之位OLTP. Analytical:用户对分析、报告、预测等方面感兴趣。这类数据库很少有嵌入和更新。主要目的是为了尽快获取和分析数据。官方名称之为OLAP. 换句话说,如果你想以嵌入、更新、删除为重点,可选择常规化的表单设计或者创建一个简单的非常规化的数据架构。 下面是一个简单的图表,左侧显示名称和地址,采用非规范化结构设计出的一款简单的常规表单。 Rule2:将数据按照逻辑思维分成不同的块,让生活更简单 这个规则其实就是“三范式”中的第一范式。这样设计的目标,是为了当你需要查询套多的字符串解析功能时,如子串,charindexetc,它能为你提供这项功能. 例如,注意观看下面的图表,如果你想查询某个学生的姓名,通过“Koirala”和“Harisingh"来进行区分。 因此,更好的方法就是打破数据逻辑思维,以便我们编写更加简洁、容易查询的表单。 Rule3:当数据太多时,rule2不可用 开发者们的思维有时很单一,如果你告诉他们某种方式,他们会一直这么做下去,要知道过度的使用会造成不必要的麻烦。正如我们之前谈到的rule2,首先要进行分解,明确自己的需求。例如,当你看到电话号码字段时,你可以在ISD代码上进行操作区分这些电话号码(直到满足你的需求)。尽管这是不错的方法,但会给你带来更多的并发症。 Rule4:将重复、不统一的数据视作你最大的敌人 聚焦和重构复制数据.我比较担心的不是复制数据所需要的磁盘空间而是它因此而造成的混乱。 从下面的图表中,“5thStandard”和“Fifthstandard”意思是相同的,你可以说是因为数据或者验证数据录入到你的系统原因,如果你想通过报表来显示他们的不同之处,从用户的角度开看,这是非常困难的. 其中一个解决方法就是将不同的任务栏把相同的数据通过新建一个键入值联接在一起.如图.我们通过创建一个新的条目“Standards”即可将数据重新排,显示相同的部分。 Rule5:注意被分隔符分割的数据 前面的规则2即“第一范式”提到避免数组重复,如图所示。如果你看到教学大纲紧密排列在一起,这个领域中需要很多数据来填充,这种我们称之为“重复数组”。如果我们必须操纵这些数据,单凭查询是很困难的,我甚至还怀疑是否具备这个查询功能。 这些带分隔符的数据需要特别注意,如何利用更好的方法将这些数据移动到一个不同的任务栏中,以便更好的分类呢?如图: 如图所示,可以看到我创建了一个独立的教学科目条目,然后列出了与之有相关联的科目。这种方法主要适用于在教学大纲领域,避免过多的重复和数据分隔符中。 Rule6:当心数据依赖 观察该领域中的部分列表。如图,我们创建了rollnumber和standard,可以看到教学科目紧密联系在一起,但与学生学习的科目没有直接关联。如果我们想给每位学生更新教学科目,这似乎看起来是不符合逻辑的,但是通过键入standard条目转换这些数据就可达到目的。 这个规则告诉我们“所有的键入都应该依赖主键".Allkeysshoulddependonthefullprimarykeyandnotpartially。 Rule7:选择派生列 如果你想进行OLTP应用首先得筛选出派生列,在OLAP中我们需要做一些求和,方可获得uixie很好的性能。如图,求的平均数需要利用marks和subject两列。 这个规则被称为第三范式,“不应该有依赖于非主键的列”(Nocolumnsshoulddependonothernon—primarykeycolumns)我个人认为是不能盲目使用此规则.如果该数据是计算过的数据,看清状况然后在决定实施第三范式。 Rule8:如果性能很关键,不要避开冗余

17****21
实名认证
内容提供者


最近下载