首页 > 运维 > 知识 > 数据库整体设计都设计哪些,如何设计一个优秀的数据库

数据库整体设计都设计哪些,如何设计一个优秀的数据库

来源:整理 时间:2025-01-12 18:50:53 编辑:黑码技术 手机版

1,如何设计一个优秀的数据库

SQL Server本身就是一个完善的数据库,提供可视化编程,后台完成所有拖放处理操作,不管有没有数据都可以使用,不需要编译。一个比较合理的数据库设计应该考虑数据的交互性和挖掘能力、处理效率以及日志记录。建立数据表,注意以下几点:表建立的时候要有主键和索引,表与表之间要能使用主键相联系,举例说在A表里我做完一次记录要生成一个单号,B表里面是依据单号来做下一个流程,而不是依据记录的每一条数据取名尽量使用英文+下划线,SQL Server里对汉字需要转码,影响工作效率,按照他的默认编码方式操作有助于提高数据处理速度建立数据表的列数不要太多,用编码规则来建立逻辑注意字段存储空间,限制字段长度,少用注释和image存储过程尽量简洁实用建立视图,为了别的客户端使用,尽量建立视图,做好完整的数据分析,别的接口程序或者客户端直接就可以拿去使用。做视图注意几点:多个表操作写在一个视图里,不要嵌套太多视图连接查询要适当的筛选跨服务器操作视图,要建立服务器链接表,尽量使用内网链接,把服务器链接表做成查询视图,放在本地服务器数据库里,这样就等同本地操作视图之间保留连接字段作为主要索引建立计划作业,有计划地进行数据同步更新和备份标识工作,注意事项:备份数据尽量放数据库里同步复制计划任务避开工作高峰期建立存储过程,记录操作日志,把日志以数据表的形式存储,注意事项:存储过程对本表操作,不要交互太多表精简参数数量,注意参数存储空间对记录修改删除、更新标记的时候尽量使用时间来索引建立关系图,给表与表之间建立直接关系,整理整体挖掘数据性能。建立计划更新任务,优化数据库整体性能。

如何设计一个优秀的数据库

2,数据库系统包含哪些内容

你说的是数据库系统吧,数据库系统有很多,主流的有oracle、db2、mysql、sqlserver,这些都是关系型数据库,非主流的有sybase(如今市场份额逐步萎缩)等,非结构化数据库也是非主流的,就是nosql等列式数据库,这些数据针对大数据有不错的效果。 数据包含的内容就多了去了,总体分为开发和管理(即运维),两者需掌握的东西相差很大,前者需要了解sql的编写,存储过程,触发器,函数,程序调优等开发,粗概念的了解数据库内容机制;后者需要掌握数据库的内部机制,而且要熟练掌握,包括操作系统也要比较熟悉,因为数据库与操作系统之间的关系十分紧密,每个数据库内部机制相差很大,即使是一个数据库的不同版本的差异有时也很大,除此之外,DBA还需要掌握sql脚本和shell脚本、linux等操作系统的知识,这些都有助于管理数据库,还有dba与前端开发人员也需要交流,所以dba也需要知道开发接口等知识,所以一个优秀的dba是很全面的,因为在大型公司中,dba往往是企业的核心,不过分的说甚至是一个大型项目成败与否的决定因素。 sql语言是面向集合,它是结构化的语言,sql是关系数据库标准的查询语言,不同数据库之间的sql语法大同小异,它具有数据查询,定义,操作,控制的功能(这些功能需要权限才能获得)。 先写到这,不懂再追问吧。
简单的说数据库是用来存放东西的,然后动过代码把数据给体现出来。
为什么这么问?是想有个指导意见吗? 就我们所知,其一搞懂原理,完成mysql的安装,表格,增删查改的操作 其二是数据结构和设计 主要目的是理清各方关系,并且绘制出表格。

数据库系统包含哪些内容

3,数据库系统一般由哪些部分组成

数据库系统由哪几部分组成?数据库系统DBS(Data Base System,简称DBS)通常由软件、数据库和数据管理员组成。其软件主要包括操作系统、各种宿主语言、实用程序以及数据库管理系统。数据库由数据库管理系统统一管理,数据的插入、修改和检索均要通过数据库管理系统进行。数据管理员负责创建、监控和维护整个数据库,使数据能被任何有权使用的人有效使用。数据库管理员一般是由业务水平较高、资历较深的人员担任。 数据库系统一般由4个部分组成: (1)数据库(database,DB)是指长期存储在计算机内的,有组织,可共享的数据的集合。数据库中的数据按一定的数学模型组织、描述和存储,具有较小的冗余,较高的数据独立性和易扩展性,并可为各种用户共享。 (2)硬件:构成计算机系统的各种物理设备,包括存储所需的外部设备。硬件的配置应满足整个数据库系统的需要。 (3)软件:包括操作系统、数据库管理系统及应用程序。数据库管理系统(database management system,DBMS)是数据库系统的核心软件,是在操作系统的支持下工作,解决如何科学地组织和存储数据,如何高效获取和维护数据的系统软件。其主要功能包括:数据定义功能、数据操纵功能、数据库的运行管理和数据库的建立与维护。 (4)人员:主要有4类。第一类为系统分析员和数据库设计人员:系统分析员负责应用系统的需求分析和规范说明,他们和用户及数据库管理员一起确定系统的硬件配置,并参与数据库系统的概要设计。数据库设计人员负责数据库中数据的确定、数据库各级模式的设计。第二类为应用程序员,负责编写使用数据库的应用程序。这些应用程序可对数据进行检索、建立、删除或修改。第三类为最终用户,他们利用系统的接口或查询语言访问数据库。第四类用户是数据库管理员(data base administrator,DBA),负责数据库的总体信息控制。DBA的具体职责包括:具体数据库中的信息内容和结构,决定数据库的存储结构和存取策略,定义数据库的安全性要求和完整性约束条件,监控数据库的使用和运行,负责数据库的性能改进、数据库的重组和重构,以提高系统的性能。 其中应用程序包含在软件范围内,是指数据库应用系统,比如开发工具、人才管理系统、信息管理系统等。 层次关系可参见如下图:

数据库系统一般由哪些部分组成

4,简述数据库应用系统的设计步骤

数据库应用系统的开发是一项软件工程。一般可分为以下几个阶段:   1.规划   2.需求分析   3.概念模型设计   4. 逻辑设计   5.物理设计   6.程序编制及调试   7.运行及维护。   这些阶段的划分目前尚无统一的标准,各阶段间相互联接,而且常常需要回溯修正。   在数据库应用系统的开发过程中,每个阶段的工作成果就是写出相应的文档。每个阶段都是在上一阶段工作成果的基础上继续进行,整个开发工程是有依据、有组织、有计划、有条不紊地展开工作。   1.规划   规划的主要任务就是作必要性及可行性分析。   在收集整理有关资料的基础上,要确定将建立的数据库应用系统与周边的关系,要对应用系统定位,其规模的大小、所处的地位、应起的作用均须作全面的分析和论证。   明确应用系统的基本功能,划分数据库支持的范围。分析数据来源、数据采集的方式和范围,研究数据结构的特点,估算数据量的大小,确立数据处理的基本要求和业务的规范标准。   规划人力资源调配。对参与研制和以后维护系统运作的管理人员、技术人员的技术业务水平提出要求,对最终用户、操作员的素质作出评估。   拟定设备配置方案。论证计算机、网络和其他设备在时间、空间两方面的处理能力,要有足够的内外存容量,系统的响应速度、网络传输和输入输出能力应满足应用需求并留有余量。要选择合适的os,dbms和其它软件。设备配置方案要在使用要求、系统性能、购置成本和维护代价各方面综合权衡。   对系统的开发、运行、维护的成本作出估算。预测系统效益的期望值。   拟定开发进度计划,还要对现行工作模式如何向新系统过渡作出具体安排。   规划阶段的工作成果是写出详尽的可行性分析报告和数据库应用系统规划书。内容应包括:系统的定位及其功能、数据资源及数据处理能力、人力资源调配、设备配置方案、开发成本估算、开发进度计划等。   可行性分析报告和数据库应用系统规划书经审定立项后,成为后续开发工作的总纲。  数据库应用系统的开发是一项软件工程,本文介绍了数据库应用系统的开发步骤……   2.需求分析   需求分析大致可分成三步来完成。   (1) 需求信息的收集, 需求信息的收集一般以机构设置和业务活动为主干线,从高层中层到低层逐步展开   (2) 需求信息的分析整理, 对收集到的信息要做分析整理工作。数据流图(dfd, data flow diagram)是业务流程及业务中数据联系的形式描述。图4.1是一个简单的dfd 示例。   数据字典(dd, data dictionary)详细描述系统中的全部数据。   数据字典包含以下几个部分。   · 数据项:是数据的原子单位。   · 数据组项:由若干数据项组成。   · 数据流:表示某一数据加工过程的输入/输出数据。   · 数据存储:是处理过程中要存取的数据。   · 数据加工过程 数据加工过程的描述包括:数据加工过程名、说明、输入、输出、加工处理工作摘要、加工处理频度、加工处理的数据量、响应时间要求等。   数据流图既是需求分析的工具,也是需求分析的成果之一。数据字典是进行数据收集和数据分析的主要成果。   (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) 扩充系统的功能   在维持原有系统功能和性能的基础上,适应环境和需求的变化,采纳用户的合理意见,对原有系统进行扩充,增加新的功能。

5,怎样设计一个好的数据库

数据库设计(Database Design)是指对于一个给定的应用环境,构造最优的数据库模式,建立数据库及其应用系统,使之能够有效地存储数据,满足各种用户的应用需求(信息要求和处理要求)。在数据库领域内,常常把使用数据库的各类系统统称为数据库应用系统。一、数据库和信息系统(1)数据库是信息系统的核心和基础,把信息系统中大量的数据按一定的模型组织起来,提供存储、维护、检索数据的功能,使信息系统可以方便、及时、准确地从数据库中获得所需的信息。(2)数据库是信息系统的各个部分能否紧密地结合在一起以及如何结合的关键所在。(3)数据库设计是信息系统开发和建设的重要组成部分。(4)数据库设计人员应该具备的技术和知识:数据库的基本知识和数据库设计技术计算机科学的基础知识和程序设计的方法和技巧软件工程的原理和方法应用领域的知识二、数据库设计的特点 数据库建设是硬件、软件和干件的结合三分技术,七分管理,十二分基础数据技术与管理的界面称之为“干件”数据库设计应该与应用系统设计相结合结构(数据)设计:设计数据库框架或数据库结构行为(处理)设计:设计应用程序、事务处理等结构和行为分离的设计传统的软件工程忽视对应用中数据语义的分析和抽象,只要有可能就尽量推迟数据结构设计的决策早期的数据库设计致力于数据模型和建模方法研究,忽视了对行为的设计如图:三、数据库设计方法简述 手工试凑法设计质量与设计人员的经验和水平有直接关系缺乏科学理论和工程方法的支持,工程的质量难以保证数据库运行一段时间后常常又不同程度地发现各种问题,增加了维护代价规范设计法手工设计方基本思想过程迭代和逐步求精规范设计法(续)典型方法:(1)新奥尔良(New Orleans)方法:将数据库设计分为四个阶段S.B.Yao方法:将数据库设计分为五个步骤I.R.Palmer方法:把数据库设计当成一步接一步的过程(2)计算机辅助设计ORACLE Designer 2000SYBASE PowerDesigner四、数据库设计的基本步骤数据库设计的过程(六个阶段) 1.需求分析阶段准确了解与分析用户需求(包括数据与处理)是整个设计过程的基础,是最困难、最耗费时间的一步2.概念结构设计阶段是整个数据库设计的关键通过对用户需求进行综合、归纳与抽象,形成一个独立于具体DBMS的概念模型3.逻辑结构设计阶段将概念结构转换为某个DBMS所支持的数据模型对其进行优化4.数据库物理设计阶段为逻辑数据模型选取一个最适合应用环境的物理结构(包括存储结构和存取方法)5.数据库实施阶段运用DBMS提供的数据语言、工具及宿主语言,根据逻辑设计和物理设计的结果建立数据库,编制与调试应用程序,组织数据入库,并进行试运行6.数据库运行和维护阶段数据库应用系统经过试运行后即可投入正式运行。在数据库系统运行过程中必须不断地对其进行评价、调整与修改设计特点:在设计过程中把数据库的设计和对数据库中数据处理的设计紧密结合起来将这两个方面的需求分析、抽象、设计、实现在各个阶段同时进行,相互参照,相互补充,以完善两方面的设计设计过程各个阶段的设计描述:如图:五、数据库各级模式的形成过程1.需求分析阶段:综合各个用户的应用需求2.概念设计阶段:形成独立于机器特点,独立于各个DBMS产品的概念模式(E-R图)3.逻辑设计阶段:首先将E-R图转换成具体的数据库产品支持的数据模型,如关系模型,形成数据库逻辑模式;然后根据用户处理的要求、安全性的考虑,在基本表的基础上再建立必要的视图(View),形成数据的外模式4.物理设计阶段:根据DBMS特点和处理的需要,进行物理存储安排,建立索引,形成数据库内模式 六、数据库设计技巧1. 设计数据库之前(需求分析阶段)1) 理解客户需求,询问用户如何看待未来需求变化。让客户解释其需求,而且随着开发的继续,还要经常询问客户保证其需求仍然在开发的目的之中。2) 了解企业业务可以在以后的开发阶段节约大量的时间。3) 重视输入输出。在定义数据库表和字段需求(输入)时,首先应检查现有的或者已经设计出的报表、查询和视图(输出)以决定为了支持这些输出哪些是必要的表和字段。举例:假如客户需要一个报表按照邮政编码排序、分段和求和,你要保证其中包括了单独的邮政编码字段而不要把邮政编码糅进地址字段里。4) 创建数据字典和ER 图表ER 图表和数据字典可以让任何了解数据库的人都明确如何从数据库中获得数据。ER图对表明表之间关系很有用,而数据字典则说明了每个字段的用途以及任何可能存在的别名。对SQL 表达式的文档化来说这是完全必要的。5) 定义标准的对象命名规范数据库各种对象的命名必须规范。2. 表和字段的设计(数据库逻辑设计)表设计原则1) 标准化和规范化数据的标准化有助于消除数据库中的数据冗余。标准化有好几种形式,但Third Normal Form(3NF)通常被认为在性能、扩展性和数据完整性方面达到了最好平衡。简单来说,遵守3NF 标准的数据库的表设计原则是:“One Fact in One Place”即某个表只包括其本身基本的属性,当不是它们本身所具有的属性时需进行分解。表之间的关系通过外键相连接。它具有以下特点:有一组表专门存放通过键连接起来的关联数据。举例:某个存放客户及其有关定单的3NF 数据库就可能有两个表:Customer 和Order。Order 表不包含定单关联客户的任何信息,但表内会存放一个键值,该键指向Customer 表里包含该客户信息的那一行。事实上,为了效率的缘故,对表不进行标准化有时也是必要的。2) 数据驱动采用数据驱动而非硬编码的方式,许多策略变更和维护都会方便得多,大大增强系统的灵活性和扩展性。举例,假如用户界面要访问外部数据源(文件、XML 文档、其他数据库等),不妨把相应的连接和路径信息存储在用户界面支持表里。还有,如果用户界面执行工作流之类的任务(发送邮件、打印信笺、修改记录状态等),那么产生工作流的数据也可以存放在数据库里。角色权限管理也可以通过数据驱动来完成。事实上,如果过程是数据驱动的,你就可以把相当大的责任推给用户,由用户来维护自己的工作流过程。3) 考虑各种变化在设计数据库的时候考虑到哪些数据字段将来可能会发生变更。举例,姓氏就是如此(注意是西方人的姓氏,比如女性结婚后从夫姓等)。所以,在建立系统存储客户信息时,在单独的一个数据表里存储姓氏字段,而且还附加起始日和终止日等字段,这样就可以跟踪这一数据条目的变化。字段设计原则4) 每个表中都应该添加的3 个有用的字段dRecordCreationDate,在VB 下默认是Now(),而在SQL Server ? 下默认为GETDATE()sRecordCreator,在SQL Server 下默认为NOT NULL DEFAULT ? USERnRecordVersion,记录的版本标记;有助于准确说明记录中出现null 数据或者丢失数据的原因 ?5) 对地址和电话采用多个字段描述街道地址就短短一行记录是不够的。Address_Line1、Address_Line2 和Address_Line3 可以提供更大的灵活性。还有,电话号码和邮件地址最好拥有自己的数据表,其间具有自身的类型和标记类别。6) 使用角色实体定义属于某类别的列在需要对属于特定类别或者具有特定角色的事物做定义时,可以用角色实体来创建特定的时间关联关系,从而可以实现自我文档化。举例:用PERSON 实体和PERSON_TYPE 实体来描述人员。比方说,当John Smith, Engineer 提升为John Smith, Director 乃至最后爬到John Smith, CIO 的高位,而所有你要做的不过是改变两个表PERSON 和PERSON_TYPE 之间关系的键值,同时增加一个日期/时间字段来知道变化是何时发生的。这样,你的PERSON_TYPE 表就包含了所有PERSON 的可能类型,比如Associate、Engineer、Director、CIO 或者CEO 等。还有个替代办法就是改变PERSON 记录来反映新头衔的变化,不过这样一来在时间上无法跟踪个人所处位置的具体时间。7) 选择数字类型和文本类型尽量充足在SQL 中使用smallint 和tinyint 类型要特别小心。比如,假如想看看月销售总额,总额字段类型是smallint,那么,如果总额超过了$32,767 就不能进行计算操作了。而ID 类型的文本字段,比如客户ID 或定单号等等都应该设置得比一般想象更大。假设客户ID 为10 位数长。那你应该把数据库表字段的长度设为12 或者13 个字符长。但这额外占据的空间却无需将来重构整个数据库就可以实现数据库规模的增长了。8) 增加删除标记字段在表中包含一个“删除标记”字段,这样就可以把行标记为删除。在关系数据库里不要单独删除某一行;最好采用清除数据程序而且要仔细维护索引整体性。 3. 选择键和索引(数据库逻辑设计)键选择原则:1) 键设计4 原则为关联字段创建外键。 ?所有的键都必须唯一。 ?避免使用复合键。 ?外键总是关联唯一的键字段。 ?2) 使用系统生成的主键设计数据库的时候采用系统生成的键作为主键,那么实际控制了数据库的索引完整性。这样,数据库和非人工机制就有效地控制了对存储数据中每一行的访问。采用系统生成键作为主键还有一个优点:当拥有一致的键结构时,找到逻辑缺陷很容易。3) 不要用用户的键(不让主键具有可更新性)在确定采用什么字段作为表的键的时候,可一定要小心用户将要编辑的字段。通常的情况下不要选择用户可编辑的字段作为键。4) 可选键有时可做主键把可选键进一步用做主键,可以拥有建立强大索引的能力。索引使用原则:索引是从数据库中获取数据的最高效方式之一。95%的数据库性能问题都可以采用索引技术得到解决。1) 逻辑主键使用唯一的成组索引,对系统键(作为存储过程)采用唯一的非成组索引,对任何外键列采用非成组索引。考虑数据库的空间有多大,表如何进行访问,还有这些访问是否主要用作读写。2) 大多数数据库都索引自动创建的主键字段,但是可别忘了索引外键,它们也是经常使用的键,比如运行查询显示主表和所有关联表的某条记录就用得上。3) 不要索引memo/note 字段,不要索引大型字段(有很多字符),这样作会让索引占用太多的存储空间。4) 不要索引常用的小型表不要为小型数据表设置任何键,假如它们经常有插入和删除操作就更别这样作了。对这些插入和删除操作的索引维护可能比扫描表空间消耗更多的时间。4. 数据完整性设计(数据库逻辑设计)1) 完整性实现机制:实体完整性:主键参照完整性:父表中删除数据:级联删除;受限删除;置空值父表中插入数据:受限插入;递归插入父表中更新数据:级联更新;受限更新;置空值DBMS对参照完整性可以有两种方法实现:外键实现机制(约束规则)和触发器实现机制用户定义完整性:NOT NULL;CHECK;触发器2) 用约束而非商务规则强制数据完整性采用数据库系统实现数据的完整性。这不但包括通过标准化实现的完整性而且还包括数据的功能性。在写数据的时候还可以增加触发器来保证数据的正确性。不要依赖于商务层保证数据完整性;它不能保证表之间(外键)的完整性所以不能强加于其他完整性规则之上。3) 强制指示完整性在有害数据进入数据库之前将其剔除。激活数据库系统的指示完整性特性。这样可以保持数据的清洁而能迫使开发人员投入更多的时间处理错误条件。4) 使用查找控制数据完整性控制数据完整性的最佳方式就是限制用户的选择。只要有可能都应该提供给用户一个清晰的价值列表供其选择。这样将减少键入代码的错误和误解同时提供数据的一致性。某些公共数据特别适合查找:国家代码、状态代码等。5) 采用视图为了在数据库和应用程序代码之间提供另一层抽象,可以为应用程序建立专门的视图而不必非要应用程序直接访问数据表。这样做还等于在处理数据库变更时给你提供了更多的自由。5. 其他设计技巧1) 避免使用触发器触发器的功能通常可以用其他方式实现。在调试程序时触发器可能成为干扰。假如你确实需要采用触发器,你最好集中对它文档化。2) 使用常用英语(或者其他任何语言)而不要使用编码在创建下拉菜单、列表、报表时最好按照英语名排序。假如需要编码,可以在编码旁附上用户知道的英语。3) 保存常用信息让一个表专门存放一般数据库信息非常有用。在这个表里存放数据库当前版本、最近检查/修复(对Access)、关联设计文档的名称、客户等信息。这样可以实现一种简单机制跟踪数据库,当客户抱怨他们的数据库没有达到希望的要求而与你联系时,这样做对非客户机/服务器环境特别有用。4) 包含版本机制在数据库中引入版本控制机制来确定使用中的数据库的版本。时间一长,用户的需求总是会改变的。最终可能会要求修改数据库结构。把版本信息直接存放到数据库中更为方便。 5) 编制文档对所有的快捷方式、命名规范、限制和函数都要编制文档。采用给表、列、触发器等加注释的数据库工具。对开发、支持和跟踪修改非常有用。对数据库文档化,或者在数据库自身的内部或者单独建立文档。这样,当过了一年多时间后再回过头来做第2 个版本,犯错的机会将大大减少。6) 测试、测试、反复测试建立或者修订数据库之后,必须用用户新输入的数据测试数据字段。最重要的是,让用户进行测试并且同用户一道保证选择的数据类型满足商业要求。测试需要在把新数据库投入实际服务之前完成。7) 检查设计在开发期间检查数据库设计的常用技术是通过其所支持的应用程序原型检查数据库。换句话说,针对每一种最终表达数据的原型应用,保证你检查了数据模型并且查看如何取出数据。
文章TAG:数据数据库整体整体设计数据库整体设计都设计哪些

最近更新

  • 搜狗插件管理,搜狗浏览器flash插件搜狗插件管理,搜狗浏览器flash插件

    搜狗如何安装浏览器插件-1/Browser插件安装指南1。在浏览器右上角的扩展栏中,单击最右边圆圈中有三个白点的扩展管理按钮,Tampermonkey油猴插件管理Device搜狗浏览器可以吗搜狗浏览器兼.....

    知识 日期:2025-01-12

  • python 桌面程序跨平台,跨平台属于Python语言的一个特点python 桌面程序跨平台,跨平台属于Python语言的一个特点

    python编程与开发app教程(用于准备自学编程软件入门python开发应用程序NeedpythonModulekivy。简而言之,这是一个python-2程序开发框架,一系列python教程,免费提供,遇到bug及时反馈,与纽扣.....

    知识 日期:2025-01-12

  • 3dmax地板生成器插件3dmax地板生成器插件

    3dmax造型木地板怎么做?Terrain插件可用于3dsMax的以下版本。3dmax如何在平面上粘贴地图地板?3dmaxvray调节凹凸木地板材料...3Dmax热门教程推荐3Dmax零基础室内设计系统化建模教程3dmax.....

    知识 日期:2025-01-12

  • 文件控制和维护程序,管理评审控制程序文件文件控制和维护程序,管理评审控制程序文件

    塑料行业的ISO9001质量体系有哪些程序-2程序-2/质量方针、目标和管理程序1234566。-2/控制,记录控制程序文件管理评审的管理文件,内部质量审核,质量信息管理、数据分析与管理、管理工作环.....

    知识 日期:2025-01-12

  • ei数据库会议论文是哪个选项,如何在ei数据库里检索一个国际会议论文的收录情况ei数据库会议论文是哪个选项,如何在ei数据库里检索一个国际会议论文的收录情况

    如何在ei数据库里检索一个国际会议论文的收录情况2,会议论文ei核心检索和ei检索的区别3,如何投EI会议4,怎样发表EI会议论文5,IFACPapersOnline收录的IFAC会议论文会入EI库吗1,如何在ei数据.....

    知识 日期:2025-01-12

  • 数据库论文软件有哪些,麻烦大家推荐几个数据库较大的本科论文查重软件吗数据库论文软件有哪些,麻烦大家推荐几个数据库较大的本科论文查重软件吗

    麻烦大家推荐几个数据库较大的本科论文查重软件吗论文检测行业最大的就是知网,另外还有gocheck,paperpass,如果是本科的话,这三个都能满足你。早检测的论文检测系统包括:知网、万方、维普、.....

    知识 日期:2025-01-12

  • 网易相册插件,网易buff插件网易相册插件,网易buff插件

    我经常用网易相册。如何在网易相册上传照片?上传相册有一个插件需要安装,但是网易blog相册就可以了,163邮箱中网易相册中的照片如何上传?在网易相册)上传照片有三种方式:单张上传照片网易.....

    知识 日期:2025-01-12

  • qr方法matlab程序qr方法matlab程序

    matlab,matlab调试方便,但效率较低。可以先把算法写在matlab上,做好了再重新写成C,OpenCv和matlab我都用过,急求matlab复矩阵的QR分解码,我知道matlab本身有qr功能,但是现在需要...从你提问的.....

    知识 日期:2025-01-12