首页数据库数据库开发规范,数据库开发规范详细介绍[1]

数据库开发规范,数据库开发规范详细介绍[1]

编程之家2023-10-20115次浏览

这篇文章给大家聊聊关于数据库开发规范,以及数据库开发规范详细介绍[1]对应的知识点,希望对各位有所帮助,不要忘了收藏本站哦。

数据库开发规范,数据库开发规范详细介绍[1]

数据库开发规范详细介绍[1]

一.数据表和字段的设计

表设计原则

标准化和规范化

数据的标准化有助于消除数据库中的数据冗余标准化有好几种形式我们在这里采用Third Normal Form( NF)因为 NF在性能扩展性和数据完整性方面达到了最好平衡遵守 NF标准的数据库某个表只包括其本身基本的属性当不是它们本身所具有的属性时需进行分解表之间的关系通过外键相连接它具有以下特点有一组表专门存放通过键连接起来的关联数据

考虑各种变化

数据库开发规范,数据库开发规范详细介绍[1]

在设计数据库的时候考虑到哪些数据字段将来可能会发生变更

字段设计原则)每个表中都应该添加的个有用的字段即要求每张数据表中字段不得少于个)选择数字类型和文本类型尽量充足在字段类型为数字或文本时其长度最好比实际所需的大一些)增加自动增长的操作ID字段(czid))增加记录创建的日期字段(CreateDate))增加删除标记字段(isvoid)在表中包含一个删除标记字段这样就可以把行标记为删除在关系数据库里不单独删除某一行一般采用清除数据程序而且要仔细维护索引整体性

二.键和索引的设计

键选择原则

)为关联字段创建外键)所有的键都必须唯一)避免使用复合键)外键总是关联唯一的键字段

使用系统生成的主键设计数据库的时候采用系统生成的键作为主键那么实际控制了数据库的索引完整性这样数据库和非人工机制就有效地控制了对存储数据中每一行的访问采用系统生成键作为主键还有一个优点当拥有一致的键结构时找到逻辑缺陷很容易不要用用户的键(不让主键具有可更新性)在确定采用什么字段作为表的键的时候小心用户将要编辑的字段通常的情况下不要选择用户可编辑的字段作为键

数据库开发规范,数据库开发规范详细介绍[1]

可选键有时可做主键把可选键进一步用做主键可以拥有建立强大索引的能力

索引使用原则

索引是从数据库中获取数据的最高效方式之一%的数据库性能问题都可以采用索引技术得到解决

索引外键大多数数据库都索引自动创建的主键字段但是可别忘了索引外键它们也是经常使用的键比如运行查询显示主表和所有关联表的某条记录就用得上不要索引大型字段(有很多字符)这样作会让索引占用太多的存储空间

不要索引常用的小型表不要为小型数据表设置任何键假如它们经常有插入和删除操作就更别这样作了对这些插入和删除操作的索引维护可能比扫描表空间消耗更多的时间

三数据完整性设计

完整性实现机制实体完整性主键

参照完整性父表中删除数据级联删除受限删除置空值父表中插入数据受限插入递归插入父表中更新数据级联更新受限更新置空值

DBMS对参照完整性可以有两种方法实现外键实现机制(约束规则)和触发器实现机制

用户定义完整性 NOT NULL CHECK触发器

用约束而非商务规则强制数据完整性采用数据库系统实现数据的完整性这不但包括通过标准化实现的完整性而且还包括数据的功能性在写数据的时候还可以增加触发器来保证数据的正确性不要依赖于商务层保证数据完整性它不能保证表之间(外键)的完整性所以不能强加于其他完整性规则之上

强制指示完整性在有害数据进入数据库之前将其剔除激活数据库系统的指示完整性特性这样可以保持数据的清洁而能迫使开发人员投入更多的时间处理错误条件

使用查找控制数据完整性控制数据完整性的最佳方式就是限制用户的选择只要有可能都应该提供给用户一个清晰的价值列表供其选择这样将减少键入代码的错误和误解同时提供数据的一致性

采用视图为了在数据库和应用程序代码之间提供另一层抽象可以为应用程序建立专门的视图而不必非要应用程序直接访问数据表这样做还等于在处理数据库变更时给你提供了更多的自由

lishixinzhi/Article/program/SQL/201311/16258

数据库设计需要遵守的设计规范

数据库的开发对于后台编程程序员来说是必备能力之一了,而今天我们就一起来了解一下,关于数据库开发的设计规范都有哪些类型,北京北大青鸟希望通过对本文的阅读,大家对于数据库开发有更多的了解。

一、数据库命令规范

所有数据库对象名称必须使用小写字母并用下划线分割

所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来)

数据库对象的命名要能做到见名识意,并且后不要超过32个字符

临时库表必须以tmp_为前缀并以日期为后缀,备份表必须以bak_为前缀并以日期(时间戳)为后缀

所有存储相同数据的列名和列类型必须一致(一般作为关联列,如果查询时关联列类型不一致会自动进行数据类型隐式转换,会造成列上的索引失效,导致查询效率降低)

二、数据库基本设计规范

1、所有表必须使用Innodb存储引擎

没有特殊要求(即Innodb无法满足的功能如:列存储,存储空间数据等)的情况下,所有表必须使用Innodb存储引擎(mysql5.5之前默认使用Myisam,5.6以后默认的为Innodb)Innodb支持事务,支持行级锁,更好的恢复性,高并发下性能更好

2、数据库和表的字符集统一使用UTF8

兼容性更好,统一字符集可以避免由于字符集转换产生的乱码,不同的字符集进行比较前需要进行转换会造成索引失效

3、所有表和字段都需要添加注释

使用comment从句添加表和列的备注从一开始就进行数据字典的维护

4、尽量控制单表数据量的大小,建议控制在500万以内

500万并不是MySQL数据库的限制,过大会造成修改表结构,备份,恢复都会有很大的问题

可以用历史数据归档(应用于日志数据),分库分表(应用于业务数据)等手段来控制数据量大小

5、谨慎使用MySQL分区表

分区表在物理上表现为多个文件,在逻辑上表现为一个表谨慎选择分区键,跨分区查询效率可能更低建议采用物理分表的方式管理大数据

6、尽量做到冷热数据分离,减小表的宽度

MySQL限制每个表多存储4096列,并且每一行数据的大小不能超过65535字节减少磁盘IO,保证热数据的内存缓存命中率(表越宽,把表装载进内存缓冲池时所占用的内存也就越大,也会消耗更多的IO)更有效的利用缓存,避免读入无用的冷数据经常一起使用的列放到一个表中(避免更多的关联操作)

简述数据库应用系统开发的一般过程

数据库应用系统的开发是一项软件工程。一般可分为以下几个阶段:1.规划2.需求分析3.概念模型设计4.逻辑设计5.物理设计6.程序编制及调试7.运行及维护。这些阶段的划分目前尚无统一的标准,各阶段间相互联接,而且常常需要回溯修正。在数据库应用系统的开发过程中,每个阶段的工作成果就是写出相应的文档。每个阶段都是在上一阶段工作成果的基础上继续进行,整个开发工程是有依据、有组织、有计划、有条不紊地展开工作。1.规划规划的主要任务就是作必要性及可行性分析。在收集整理有关资料的基础上,要确定将建立的数据库应用系统与周边的关系,要对应用系统定位,其规模的大小、所处的地位、应起的作用均须作全面的分析和论证。明确应用系统的基本功能,划分数据库支持的范围。分析数据来源、数据采集的方式和范围,研究数据结构的特点,估算数据量的大小,确立数据处理的基本要求和业务的规范标准。规划人力资源调配。对参与研制和以后维护系统运作的管理人员、技术人员的技术业务水平提出要求,对最终用户、操作员的素质作出评估。拟定设备配置方案。论证计算机、网络和其他设备在时间、空间两方面的处理能力,要有足够的内外存容量,系统的响应速度、网络传输和输入输出能力应满足应用需求并留有余量。要选择合适的os,dbms和其它软件。设备配置方案要在使用要求、系统性能、购置成本和维护代价各方面综合权衡。对系统的开发、运行、维护的成本作出估算。预测系统效益的期望值。拟定开发进度计划,还要对现行工作模式如何向新系统过渡作出具体安排。规划阶段的工作成果是写出详尽的可行性分析报告和数据库应用系统规划书。内容应包括:系统的定位及其功能、数据资源及数据处理能力、人力资源调配、设备配置方案、开发成本估算、开发进度计划等。可行性分析报告和数据库应用系统规划书经审定立项后,成为后续开发工作的总纲。数据库应用系统的开发是一项软件工程,本文介绍了数据库应用系统的开发步骤2.需求分析需求分析大致可分成三步来完成。(1)需求信息的收集,需求信息的收集一般以机构设置和业务活动为主干线,从高层中层到低层逐步展开(2)需求信息的分析整理,对收集到的信息要做分析整理工作。数据流图(dfd,dataflowdiagram)是业务流程及业务中数据联系的形式描述。图4.1是一个简单的dfd示例。数据字典(dd,datadictionary)详细描述系统中的全部数据。数据字典包含以下几个部分。·数据项:是数据的原子单位。·数据组项:由若干数据项组成。·数据流:表示某一数据加工过程的输入/输出数据。·数据存储:是处理过程中要存取的数据。·数据加工过程数据加工过程的描述包括:数据加工过程名、说明、输入、输出、加工处理工作摘要、加工处理频度、加工处理的数据量、响应时间要求等。数据流图既是需求分析的工具,也是需求分析的成果之一。数据字典是进行数据收集和数据分析的主要成果。(3)需求信息的评审.开发过程中的每一个阶段都要经过评审,确认任务是否全部完成,避免或纠正工作中出现的错误和疏漏。聘请项目外的专家参与评审,可保证评审的质量和客观性。评审可能导致开发过程回溯,甚至会反复多次。但是,一定要使全部的预期目标都达到才能让需求分析阶段的工作暂告一个段落.需求分析阶段的工作成果是写出一份既切合实际又具有预见的需求说明书,并且附以一整套详尽的数据流图和数据字典。3.概念模型设计概念模型不依赖于具体的计算机系统,他是纯粹反映信息需求的概念结构。建模是在需求分析结果的基础上展开,常常要对数据进行抽象处理。常用的数据抽象方法是‘聚集’和‘概括’。er方法是设计概念模型时常用的方法。用设计好的er图再附以相应的说明书可作为阶段成果概念模型设计可分三步完成。(1)设计局部概念模型①确定局部概念模型的范围②定义实体③定义联系④确定属性⑤逐一画出所有的局部er图,并附以相应的说明文件数据库应用系统的开发是一项软件工程,本文介绍了数据库应用系统的开发步骤(2)设计全局概念模型建立全局er图的步骤如下:①确定公共实体类型②合并局部er图③消除不一致因素④优化全局er图⑤画出全局er图,并附以相应的说明文件。(3)概念模型的评审概念模型的评审分两部分进行第一部分是用户评审。第二部分是开发人员评审。4.逻辑设计逻辑设计阶段的主要目标是把概念模型转换为具体计算机上dbms所支持的结构数据模型。逻辑设计的输入要素包括:概念模式、用户需求、约束条件、选用的dbms的特性。逻辑设计的输出信息包括:dbms可处理的模式和子模式、应用程序设计指南、物理设计指南。(1)设计模式与子模式关系数据库的模式设计可分四步完成。①建立初始关系模式②规范化处理③模式评价④修正模式经过多次的模式评价和模式修正,确定最终的模式和子模式。写出逻辑数据库结构说明书。数据库应用系统的开发是一项软件工程,本文介绍了数据库应用系统的开发步骤(2)编写应用程序设计指南根据设计好的模式和应用需求,规划应用程序的架构,设计应用程序的草图,指定每个应用程序的数据存取功能和数据处理功能梗概,提供程序上的逻辑接口。编写出应用程序设计指南。(3)编写物理设计指南。根据设计好的模式和应用需求,整理出物理设计阶段所需的一些重要数据和文档。例如,数据库的数据容量、各个关系(文件)的数据容量、应用处理频率、操作顺序、响应速度、各个应用的lra和tv、程序访问路径建议,等等。这些数据和要求将直接用于物理数据库的设计。编写出物理设计指南。5.物理设计物理设计是对给定的逻辑数据模型配置一个最适合应用环境的物理结构。物理设计的输入要素包括:模式和子模式、物理设计指南、硬件特性、os和dbms的约束、运行要求等。物理设计的输出信息主要是物理数据库结构说明书。其内容包括物理数据库结构、存储记录格式、存储记录位置分配及访问方法等。物理设计的步骤如下:(1)存储记录结构设计综合分析数据存储要求和应用需求,设计存储记录格式。(2)存储空间分配存储空间分配有两个原则:①存取频度高的数据尽量安排在快速、随机设备上,存取频度低的数据则安排在速度较慢的设备上。②相互依赖性强的数据尽量存储在同一台设备上,且尽量安排在邻近的存储空间上。从提高系统性能方面考虑,应将设计好的存储记录作为一个整体合理地分配物理存储区域。尽可能充分利用物理顺序特点,把不同类型的存储记录指派到不同的物理群中。(3)访问方法的设计一个访问方法包括存储结构和检索机构两部分。存储结构限定了访问存储记录时可以使用的访问路径;检索机构定义了每个应用实际使用的访问路径。数据库应用系统的开发是一项软件工程,本文介绍了数据库应用系统的开发步骤(4)物理设计的性能评价①查询响应时间从查询开始到有结果显示之间所经历的时间称为查询响应时间。查询响应时间可进一步细分为服务时间、等待时间和延迟时间。在物理设计过程中,要对系统的性能进行评价。性能评价包括时间、空间、效率、开销等各个方面。⊙cpu服务时间和i/o服务时间的长短取决于应用程序设计。⊙cpu队列等待时间和i/o队列等待时间的长短受计算机系统作业的影响。⊙设计者可以有限度地控制分布式数据库系统的通信延迟时间。②存储空间存储空间存放程序和数据。程序包括运行的应用程序、dbms子程序、os子程序等。数据包括用户工作区、dbms工作区、os工作区、索引缓冲区、数据缓冲区等。存储空间分为主存空间和辅存空间。设计者只能有限度地控制主存空间,例如可指定缓冲区的分配等。但设计者能够有效地控制辅存空间。③开销与效率设计中还要考虑以下各种开销,开销增大,系统效率将下降。⊙事务开销指从事务开始到事务结束所耗用的时间。更新事务要修改索引、重写物理块、进行写校验等操作,增加了额外的开销。更新频度应列为设计的考虑因素。⊙报告生成开销指从数据输入到有结果输出这段时间。报告生成占用cpu及i/o的服务时间较长。设计中要进行筛选,除去不必要的报告生成。⊙对数据库的重组也是一项大的开销。设计中应考虑数据量和处理频度这两个因数,做到避免或尽量减少重组数据库。在物理设计阶段,设计、评价、修改这个过程可能要反复多次,最终得到较为完善的物理数据库结构说明书。建立数据库时,dba依据物理数据库结构说明书,使用dbms提供的工具可以进行数据库配置。在数据库运行时,dba监察数据库的各项性能,根据依据物理数据库结构说明书的准则,及时进行修正和优化操作,保证数据库系统能够保持高效率地运行。6.程序编制及调试在逻辑数据库结构确定以后,应用程序设计的编制就可以和物理设计并行地展开程序模块代码通常先在模拟的环境下通过初步调试,然后再进行联合调试。联合调试的工作主要有以下几点:数据库应用系统的开发是一项软件工程,本文介绍了数据库应用系统的开发步骤(1)建立数据库结构根据逻辑设计和物理设计的结果,用dbms提供的数据语言(ddl)编写出数据库的源模式,经编译得到目标模式,执行目标模式即可建立实际的数据库结构。(2)调试运行数据库结构建立后,装入试验数据,使数据库进入调试运行阶段。运行应用程序,测试(3)装入实际的初始数据在数据库正式投入运行之前,还要做好以下几项工作:(1)制定数据库重新组织的可行方案。(2)制定故障恢复规范(3)制定系统的安全规范7.运行和维护数据库正式投入运行后,运行维护阶段的主要工作是:(1)维护数据库的安全性与完整性。按照制定的安全规范和故障恢复规范,在系统的安全出现问题时,及时调整授权和更改密码。及时发现系统运行时出现的错误,迅速修改,确保系统正常运行。把数据库的备份和转储作为日常的工作,一旦发生故障,立即使用数据库的最新备份予以恢复。(2)监察系统的性能。运用dbms提供的性能监察与分析工具,不断地监控着系统的运行情况。当数据库的存储空间或响应时间等性能下降时,立即进行分析研究找出原因,并及时采取措施改进。例如,可通修改某些参数、整理碎片、调整存储结构或重新组织数据库等方法,使数据库系统保持高效率地正常运作。(3)扩充系统的功能在维持原有系统功能和性能的基础上,适应环境和需求的变化,采纳用户的合理意见,对原有系统进行扩充,增加新的功能。

OK,本文到此结束,希望对大家有所帮助。

dw数据库(DW如何连接数据库)搭建传奇服务器(开传奇私服需要什么样的服务器配置)