勤哲EXCEL服务器设计之数据库范式

本文详细介绍了从第一范式到第五范式的概念及应用实例,帮助读者理解如何通过规范化的手段来减少数据冗余并提高数据一致性。

开发板推荐:天空星STM32F407VET6开发板

超高性价比 STM32主控 | 超高主频 | 一板兼容百芯 | 比赛神器 | 沉金彩色丝印

       原创写东西比较累,也一直很难抽时间写些内容,从网上找了些关于“数据库范式”的文章,转一下发个帖。如果你正在考虑使用勤哲excel服务器,那么我想说你最好了解下数据库范式。勤哲并不是excel,excel只是一种表现形式,所有的精髓还是在数据库中。因此,come on,好好看看下面摘抄的内容吧。

 

   第一范式
定义:如果关系R 中所有属性的值域都是单纯域,那么关系模式R是第一范式的
那么符合第一模式的特点就有
1)有主关键字
2)主键不能为空,
3)主键不能重复,
4)字段不可以再分
例如:
StudyNo   |   Name   |   Sex   |   Contact
20040901      john         Male      Email:kkkk@ee.net,phone:222456
20040901      mary         famale   email:kkk@fff.net phone:123455
以上的表就不符合,第一范式:主键重复(实际中数据库不允许重复的),而且Contact字段可以再分
所以变更为正确的是
StudyNo   |   Name   |   Sex   |      Email         |      Phone
20040901      john         Male       kkkk@ee.net  222456
20040902     mary         famale    kkk@fff.net    123455

第二范式:
定义:如果关系模式R是第一范式的,而且关系中每一个非主属性不部分依赖于主键,称R是第二范式的。
所以第二范式的主要任务就是
满足第一范式的前提下,消除部分函数依赖。
StudyNo   |   Name   |   Sex   |         Email         |      Phone    |   ClassNo  | ClassAddress
01                  john        Male       kkkk@ee.net     222456      200401            A楼2
02                   mary       famale    kkk@fff.net       123455      200402            A楼3
这个表完全满足于第一范式,
主键由StudyNo和ClassNo组成,这样才能定位到指定行
但是,ClassAddress部分依赖于关键字(ClassNo-〉ClassAddress),
所以要变为两个表
表一
StudyNo   |   Name   |   Sex   |      Email         |      Phone |   ClassNo
      01            john         Male       kkkk@ee.net  222456   200401     
      02           mary         famale    kkk@fff.net    123455      200402    
表二
ClassNo  | ClassAddress
200401      A楼2
200402      A楼3


第三范式:
满足第二范式的前提下,消除传递依赖。
例:
StudyNo   |   Name   |   Sex   |      Email         |      bounsLevel   |   bouns
20040901      john         Male       kkkk@ee.net   优秀                    $1000
20040902     mary         famale    kkk@fff.net       良                         $600
这个完全满足了第二范式,但是bounsLevel和bouns存在传递依赖
更改为:
StudyNo   |   Name   |   Sex   |      Email         |      bouunsNo
20040901      john         Male       kkkk@ee.net   1
20040902     mary         famale    kkk@fff.net       2
bounsNo   |   bounsLevel   |   bouns
1                   优秀                $1000
2                 良                   $600
这里我比较喜欢用bounsNo作为主键,
基于两个原因
1)不要用字符作为主键。可能有人说:如果我的等级一开始就用数值就代替呢?
2)但是如果等级名称更改了,不叫 1,2 ,3或优、良,这样就可以方便更改,所以我一般优先使用与业务无关的字段作为关键字。

一般满足前三个范式就可以避免数据冗余。

第四范式:
主要任务:满足第三范式的前提下,消除多值依赖
product   | agent |  factory
Car            A1        F1
Bus           A1         F2
Car            A2         F2
在这里,Car的定位,必须由 agent 和 Factory才能得到(所以主键由agent和factory组成),可以通过 product依赖了agent和factory两个属性
所以正确的是
表1                              表2:
product   |   agent            factory  |   product
Car            A1                  F1            Car
Bus            A1                  F2            Car
Car            A2                  F2             Bus

第五范式:
定义: 如果关系模式R中的每一个连接依赖, 都是由R的候选键所蕴含, 称R是第五范式的
看到定义,就知道是要消除连接依赖,并且必须保证数据完整
例子
A   |   B  |   C
a1      b1   c1
a2      b1   c2
a1      b2  c1
a2      b2   c2
如果要定位到特定行,必须三个属性都为关键字。
所以关系要变为 三个关系,分别是A 和B,B和C ,C和A
如下:
表1                      表2                  表3
A   |   B               B   |   C         C    |    A
a1      b1            b1      c1         c1      a1           
a1      b2            b1      c2         c1      a2

       范式可以避免数据冗余,减少数据库的空间,减轻维护数据完整性的麻烦,但是操作难,因为需要联系多个表才能得到所需要数据,而且越高范式性能就会越差。要权衡是否使用更高范式是比较麻烦。
       一般我在做项目中都,用得最多的也就是第三范式,我认为使用到第三范式也就足够了,性能好而且方便管理数据。

       看完上面的文章,你在进行勤哲excel服务器模板设计的时候,是否还会考虑将所有的字段都放到一个模板上?你是否还会希望将许多一样的字段重复定义到不同的表上?
     勤哲excel服务器并不是excel,因此希望你在做系统设计的时候,不要纯粹的站在excel的观点来进行设计,从数据库的角度去考虑,用excel的形式去表现。

开发板推荐:天空星STM32F407VET6开发板

超高性价比 STM32主控 | 超高主频 | 一板兼容百芯 | 比赛神器 | 沉金彩色丝印

Excel服务器2010安装与使用说明 (无限用户第二版) 本软件为Excel服务器2010无限用户版,没有功能和时间限制,永久使用! 软件、模板、视频教程下载地址:http://www4.qinzhe.com/chinese/download2.htm Excel服务器2010 v9.2.335 旗舰版 第一部分:软件的安装步骤 1、 下载Excel服务器2010 旗舰版; 2、 建议选择windows server 2003 (windows server 2008 店主没有测试过); 3、 安装IIS Internet信息服务管理器 ; 4、 安装.net framework 2.0 (不安装EXCEL服务器会自动装.NET 2.0); 5、 安装SQL数据库(不安装EXCEL 服务器会自动装一个兼容的MSD2000)并打好补丁,若为SQL2000则补至SP4; 6、 安装Excel服务器2010 旗舰版(安装完毕需要重新启动计算机) 第二部分:无限用户版的注册 1、 停止ES_SERVER服务; 2、 替换ESWint10.dll文件; 3、输入SN.TXT的注册信息; 4、启动“服务管理器”并重新启动计算机; 5、完成注册并查看注册信息。 1、停止ES_SERVER服务; 点击“开始”—“程序”—“Excel服务器2010”—“服务管理器”,打开“服务管理器”点击“停止”按钮使EXCEL服务停止;停止后右下标的红绿灯应变为红色,并提示“已经停止”。 2、替换ESWint10.dll文件: 找到EXCEL服务器的安装目录,将ESWint10.dll重命名(以备还原),并将无限用户第二版的ESWint10.dll“复制”—“粘贴”到这个目录里 3、输入SN.TXT的注册信息: 点击“开始”—“程序”—“Excel服务器2010”—“系统管理”,这时会报错(英文提示)如图: 点击“确定”后会弹出注册对话框并提示硬件代码“Hardware fingerprint: XXXX-XXXX”,并要求输入用户名(name)及注册码(key); 输入SN.TXT里的“Name”和“Key”再点击“OK” 会提示“注册完成”(英文) 接着弹出“系统管理台”之“管理员登录”,不要点“确定”直接关闭; 当出现这个对话框时,请直接关闭,不要输入。 4、启动“服务管理器”,并重新启动计算机; 点击“开始”—“程序”—“Excel服务器2010”—“服务管理器”,点击“启动”按钮启动EXCEL服务;右下标的红绿灯应变为绿色,并提示“正在运行”。 5、 查看注册信息。 点击“开始”—“程序”—“Excel服务器2010”—“系统管理”,在“excel 服务器”-“关于”中可看到注册后的用户数应为“无限用户”。 第一次登录sysadmin密码为空,登录后要求立即更改密码
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值