1. 原始单据与实体之间的关系
  可以是一对一、一对多、多对多的关系。在一般情况下,它们是一对一的关系:即一张原始单据对应且只对应一个实体。
在特殊情况下,它们可能是一对多或多对一的关系,即一张原始单证对应多个实体,或多张原始单证对应一个实体。
这里的实体可以理解为基本表。明确这种对应关系后,对我们设计录入界面大有好处。

  〖例1〗:一份员工履历资料,在人力资源信息系统中,就对应三个基本表:员工基本情况表、社会关系表、工作简历表。
       这就是“一张原始单证对应多个实体”的典型例子。

2. 主键与外键
  一般而言,一个实体不能既无主键又无外键。在E—R 图中, 处于叶子部位的实体, 可以定义主键,也可以不定义主键
  (因为它无子孙), 但必须要有外键(因为它有父亲)。

  主键与外键的设计,在全局数据库的设计中,占有重要地位。当全局数据库的设计完成以后,有个美国数据库设计专
  家说:“键,到处都是键,除了键之外,什么也没有”,这就是他的数据库设计经验之谈,也反映了他对信息系统核
  心(数据模型)的高度抽象思想。因为:主键是实体的高度抽象,主键与外键的配对,表示实体之间的连接。

3. 基本表的性质
  基本表与中间表、临时表不同,因为它具有如下四个特性:
   (1) 原子性。基本表中的字段是不可再分解的。
   (2) 原始性。基本表中的记录是原始数据(基础数据)的记录。
   (3) 演绎性。由基本表与代码表中的数据,可以派生出所有的输出数据。
   (4) 稳定性。基本表的结构是相对稳定的,表中的记录是要长期保存的。
  理解基本表的性质后,在设计数据库时,就能将基本表与中间表、临时表区分开来。

4. 范式标准
  基本表及其字段之间的关系, 应尽量满足第三范式。但是,满足第三范式的数据库设计,往往不是最好的设计。
  为了提高数据库的运行效率,常常需要降低范式标准:适当增加冗余,达到以空间换时间的目的。

  〖例2〗:有一张存放商品的基本表,如表1所示。“金额”这个字段的存在,表明该表的设计不满足第三范式,
  因为“金额”可以由“单价”乘以“数量”得到,说明“金额”是冗余字段。但是,增加“金额”这个冗余字段,
  可以提高查询统计的速度,这就是以空间换时间的作法。
  在Rose 2002中,规定列有两种类型:数据列和计算列。“金额”这样的列被称为“计算列”,而“单价”和
  “数量”这样的列被称为“数据列”。

  表1 商品表的表结构
  商品名称 商品型号 单价 数量 金额
  电视机 29吋 2,500 40 100,000
  
5. 通俗地理解三个范式
  通俗地理解三个范式,对于数据库设计大有好处。在数据库设计中,为了更好地应用三个范式,就必须通俗地理解
  三个范式(通俗地理解是够用的理解,并不是最科学最准确的理解):
  第一范式:1NF是对属性的原子性约束,要求属性具有原子性,不可再分解;
  第二范式:2NF是对记录的惟一性约束,要求记录有惟一标识,即实体的惟一性;
  第三范式:3NF是对字段冗余性的约束,即任何字段不能由其他字段派生出来,它要求字段没有冗余。

  没有冗余的数据库设计可以做到。但是,没有冗余的数据库未必是最好的数据库,有时为了提高运行效率,就必须降
  低范式标准,适当保留冗余数据。具体做法是:在概念数据模型设计时遵守第三范式,降低范式标准的工作放到物理
  数据模型设计时考虑。降低范式就是增加字段,允许冗余。

6. 要善于识别与正确处理多对多的关系
  若两个实体之间存在多对多的关系,则应消除这种关系。消除的办法是,在两者之间增加第三个实体。这样,原来一
  个多对多的关系,现在变为两个一对多的关系。要将原来两个实体的属性合理地分配到三个实体中去。这里的第三个
  实体,实质上是一个较复杂的关系,它对应一张基本表。一般来讲,数据库设计工具不能识别多对多的关系,但能处
  理多对多的关系。

  〖例3〗:在“图书馆信息系统”中,“图书”是一个实体,“读者”也是一个实体。这两个实体之间的关系,是一
  个典型的多对多关系:一本图书在不同时间可以被多个读者借阅,一个读者又可以借多本图书。为此,要在二者之
  间增加第三个实体,该实体取名为“借还书”,它的属性为:借还时间、借还标志(0表示借书,1表示还书),另外,
  它还应该有两个外键(“图书”的主键,“读者”的主键),使它能与“图书”和“读者”连接。

注视:

图书 1 和 该实体取名为“借还书” n
读者 1 和 该实体取名为“借还书” n

7. 主键PK的取值方法
   PK是供程序员使用的表间连接工具,可以是一无物理意义的数字串, 由程序自动加1来实现。也可以是有物理意义
  的字段名或字段名的组合。不过前者比后者好。当PK是字段名的组合时,建议字段的个数不要太多,多了不但索引
  占用空间大,而且速度也慢。

8. 正确认识数据冗余
  主键与外键在多表中的重复出现, 不属于数据冗余,这个概念必须清楚,事实上有许多人还不清楚。非键字段的重
  复出现, 才是数据冗余!而且是一种低级冗余,即重复性的冗余。高级冗余不是字段的重复出现,而是字段的派生出现。

  〖例4〗:商品中的“单价、数量、金额”三个字段,“金额”就是由“单价”乘以“数量”派生出来的,它就是冗余,
  而且是一种高级冗余。冗余的目的是为了提高处理速度。只有低级冗余才会增加数据的不一致性,因为同一数据,可
  能从不同时间、地点、角色上多次录入。因此,我们提倡高级冗余(派生性冗余),反对低级冗余(重复性冗余)。

9. E--R图没有标准答案
  信息系统的E--R图没有标准答案,因为它的设计与画法不是惟一的,只要它覆盖了系统需求的业务范围和功能内容,
  就是可行的。反之要修改E--R图。尽管它没有惟一的标准答案,并不意味着可以随意设计。好的E—R图的标准是:
  结构清晰、关联简洁、实体个数适中、属性分配合理、没有低级冗余。

10 . 视图技术在数据库设计中很有用
  与基本表、代码表、中间表不同,视图是一种虚表,它依赖数据源的实表而存在。视图是供程序员使用数据库的
  一个窗口,是基表数据综合的一种形式, 是数据处理的一种方法,是用户数据保密的一种手段。为了进行复杂处理、
  提高运算速度和节省存储空间, 视图的定义深度一般不得超过三层。 若三层视图仍不够用, 则应在视图上定义临时表,
   在临时表上再定义视图。这样反复交迭定义, 视图的深度就不受限制了。

  对于某些与国家政治、经济、技术、军事和安全利益有关的信息系统,视图的作用更加重要。这些系统的基本表完
  成物理设计之后,立即在基本表上建立第一层视图,这层视图的个数和结构,与基本表的个数和结构是完全相同。
  并且规定,所有的程序员,一律只准在视图上操作。只有数据库管理员,带着多个人员共同掌握的“安全钥匙”,
  才能直接在基本表上操作。请读者想想:这是为什么?

11. 中间表、报表和临时表
  中间表是存放统计数据的表,它是为数据仓库、输出报表或查询结果而设计的,有时它没有主键与外键(数据仓
  库除外)。临时表是程序员个人设计的,存放临时记录,为个人所用。基表和中间表由DBA维护,临时表由程序员
  自己用程序自动维护。

12. 完整性约束表现在三个方面
  域的完整性:用Check来实现约束,在数据库设计工具中,对字段的取值范围进行定义时,有一个Check按钮,通
  过它定义字段的值城。
  参照完整性:用PK、FK、表级触发器来实现。
  用户定义完整性:它是一些业务规则,用存储过程和触发器来实现。

13. 防止数据库设计打补丁的方法是“三少原则”
   (1) 一个数据库中表的个数越少越好。只有表的个数少了,才能说明系统的E--R图少而精,去掉了重复的多余的
    实体,形成了对客观世界的高度抽象,进行了系统的数据集成,防止了打补丁式的设计;

   (2) 一个表中组合主键的字段个数越少越好。因为主键的作用,一是建主键索引,二是做为子表的外键,所以组
    合主键的字段个数少了,不仅节省了运行时间,而且节省了索引存储空间;

   (3) 一个表中的字段个数越少越好。只有字段的个数少了,才能说明在系统中不存在数据重复,且很少有数据冗
    余,更重要的是督促读者学会“列变行”,这样就防止了将子表中的字段拉入到主表中去,在主表中留下许
    多空余的字段。所谓“列变行”,就是将主表中的一部分内容拉出去,另外单独建一个子表。这个方法很简
    单,有的人就是不习惯、不采纳、不执行。

  数据库设计的实用原则是:在数据冗余和处理速度之间找到合适的平衡点。“三少”是一个整体概念,综合观点,
  不能孤立某一个原则。该原则是相对的,不是绝对的。“三多”原则肯定是错误的。试想:若覆盖系统同样的功
  能,一百个实体(共一千个属性) 的E--R图,肯定比二百个实体(共二千个属性) 的E--R图,要好得多。

  提倡“三少”原则,是叫读者学会利用数据库设计技术进行系统的数据集成。数据集成的步骤是将文件系统集成
  为应用数据库,将应用数据库集成为主题数据库,将主题数据库集成为全局综合数据库。集成的程度越高,数据
  共享性就越强,信息孤岛现象就越少,整个企业信息系统的全局E—R图中实体的个数、主键的个数、属性的个数
  就会越少。

  提倡“三少”原则的目的,是防止读者利用打补丁技术,不断地对数据库进行增删改,使企业数据库变成了随意
  设计数据库表的“垃圾堆”,或数据库表的“大杂院”,最后造成数据库中的基本表、代码表、中间表、临时表
  杂乱无章,不计其数(即动态创表而增加表数量),导致企事业单位的信息系统无法维护而瘫痪。

   “三多”原则任何人都可以做到,该原则是“打补丁方法”设计数据库的歪理学说。“三少”原则是少而精的
  原则,它要求有较高的数据库设计技巧与艺术,不是任何人都能做到的,因为该原则是杜绝用“打补丁方法”
  设计数据库的理论依据。

14. 提高数据库运行效率的办法
  在给定的系统硬件和系统软件条件下,提高数据库系统的运行效率的办法是:
   (1) 在数据库物理设计时,降低范式,增加冗余, 少用触发器, 多用存储过程。
   (2) 当计算非常复杂、而且记录条数非常巨大时(例如一千万条),复杂计算要先在数据库外面,以文件系统方
    式用C++语言计算处理完成之后,最后才入库追加到表中去。这是电信计费系统设计的经验。
   (3) 发现某个表的记录太多,例如超过一千万条,则要对该表进行水平分割。水平分割的做法是,以该表主键
    PK的某个值为界线,将该表的记录水平分割为两个表(即可以表维护 表行数过大 手动分割为两个 建个两表union的视图对程序透明)。若发现某个表的字段太多,例如超过八十个,则
    垂直分割该表,将原来的一个表分解为两个表。
   (4) 对数据库管理系统DBMS进行系统优化,即优化各种系统参数,如缓冲区个数。
   (5) 在使用面向数据的SQL语言进行程序设计时,尽量采取优化算法。
    总之,要提高数据库的运行效率,必须从数据库系统级优化、数据库设计级优化、程序实现级优化,这三
    个层次上同时下功夫。

作业1:

Java学习论坛数据库需求
一.用户注册和登录
1.用户注册:用户输入用户名(用户名唯一),密码,性别,生日,电话,邮箱完成注册。用户有状态字段备用
2.用户输入用户名和密码完成登录
3.用户管理
a)查看当天注册用户
b)将用户状态设置为禁言和解禁二.学习论坛模块管理
对象关系:大板块和小模块1对多
1.大板块管理:
a)板块添加
b)板块修改
c)板块删除
2.小模块管理
a)小模块添加:要选择所在大板块
b)小模块信息修改
c)小模块删除
三.发帖管理
说明:要求注册用户且状态为正常才能发帖,用户和帖子是1对多关系
1.用户发帖:用户进入小模块后可以发帖,发帖要记录发帖人信息,小模块信息,发帖时间,发帖状态
2.用户回帖:回帖是用户针对发帖信息的回复,要记录回帖人信息,帖子信息,回帖时间,回帖状态
四.帖子管理
1.审核:后台对发帖和回帖有审核功能,审核通过则可以显示在网页,否则不能显示,操作有审核通过和审核不通过
2.置顶:可以将优秀的帖子置于板块顶端显示,当有多个帖子都置顶时按发帖时间顺序置顶
五.查看统计功能
1.查看注册总人数
2.查看大模块下的帖子总数
3.查看小模块下的帖子总数
4.查看某天的,某模块下的帖子总数
5.查看某人的所有发帖信息
6.查看每个小模块的发帖总数
7.查看每个大板块的发帖总数
8.统计发帖最多的前十名用户

作业2:

ATM自动取款机需求
一.登陆
1.界面要求:服务选择
1.老用户登陆:进入后输入卡号密码登陆
select * from user_info where card_id=? and password=?
2.新用户开户:开户需要输入身份证号,记录姓名,开户时间。然后机器给出卡号,原始密码:111111。
insert into user_info values (sq_userinfo.nextval,?,?,?,?,?,?,sysdate,'1')
卡号:当前系统时间的毫秒数:卡号=“ICBC”+毫秒数;二.服务选择
用户登陆后显示服务选择菜单:存款,取款,汇款,修改密码,查看余额。
将五个功能写成五个方法,在菜单选项中去调用
三.存款
此操作是已登录用户,输入存款金额,直接打到用户的账户上
update user-info set balance = balance+? where card_id=?
四.取款
此操作是已登录用户,输入取款金额,判断是否有足够余额,直接从用户的账户取出(要求:每次不大于3000,每天不超过5w)
2.判断当次金额3000以内
3.查询操作记录表:查询当天取款总金额
select sum(balance) from deal_info where card_id=? and deal_type=2 and trunc(deal_time)=trunc(sysdate)
4.把查询出的总金额+当前要取款金额>1w
5.取款成功后记录本次操作:
insert into deal_info values(sq_dealinfo.nextval,card_id,?,?,?,?,?)
五.汇款
此操作是已登录用户,输入汇款人账号,显示汇款人信息,确认后再输入金额,判断余额是否足够,然后打款。(要求单笔金额上限5000,每天不超过10w)
1.查询汇款人信息:
2.确认后,再查询当前用户余额是否足够:
select balance from user_info where card_id=?
3.判断当次金额5000以内
4.查询操作记录表:查询当天汇款总金额
select sum(balance) from deal_info where card_id=? and deal_type=3 and trunc(deal_time)=trunc(sysdate)
5.把查询出的总金额+当前要取款金额>1w
6.汇款成功后记录本次操作:
insert into deal_info values(sq_dealinfo.nextval,card_id,?,?,?,?,?)
六.修改密码(密码必须是6位)
此操作是已登录用户,进入修改密码服务,提示输入原始密码,提示输入新密码,提示再次确认,然后修改成功
update user_info set password=? where card_id=?
七.查看余额
此操作是已登录用户,查看当前账户的余额。
八.退卡操作:此操作后需要重新登录或者回到最起始界面。其他功能操作完后都回到服务选择菜单。

作业3:

在线考试系统
功能描述
一.后台登陆(管理员)
1.管理试卷
试卷名,科目,考试时间,题目数量,总分
2.管理试题(可以单个上传和批量上传试题)
科目,类型,题目,abcdef选项,正确答案,分数
3.给试卷添加试题,可以手动选择添加也可以机选添加
4.发布考试
发布时间,针对用户群体
二.前台登陆(用户)
1.注册和登录
2.选择自己的考试在线考试
3.查看考试结果和以往考试记录
三.系统自动阅卷统计分数并保留
四.管理员能查看考试结果和以往所有记录并且统计

转载于:https://www.cnblogs.com/wlxslsb/p/10711622.html

七、Oracle 数据库设计相关推荐

  1. (数据库系统概论|王珊)第七章数据库设计-第一节:数据库设计概述

    注意:此部分内容和软件工程的知识点重合较多,更多请点击[免费分享]软件工程核心知识点 本章较分散,各节导航如下 (数据库系统概论|王珊)第七章数据库设计-第二节:需求分析 (数据库系统概论|王珊)第七 ...

  2. 数据库系统概念总结:第七章 数据库设计和E-R模型

    周末无事水文章,期末备考的总结资料 第七章 数据库设计和E-R模型 7.1 设计过程概览 7.1.1 设计阶段 需要完整地刻画未来数据库用户的数据需求 选择数据模型,并采用所选数据模型的概念将这些需求 ...

  3. Oracle数据库设计要做到五戒

    众所周知,数据库设计的好坏直接关系到数据库运行的效率.根据笔者的经验,对于提升数据库性能来说,合理的数据库设计,比升级服务器的硬件配置,还要来的有效.但是,笔者无论是在跟同事合作,又或者是在论坛上跟相 ...

  4. 软考-架构师-第三章-数据库系统 第七节 数据库设计(读书笔记)

    版权声明 主要针对希赛出版的架构师考试教程<系统架构设计师教程(第4版)>,作者"希赛教育软考学院".完成相关的读书笔记以便后期自查,仅供个人学习使用,不得用于任何商业 ...

  5. 超大型Oracle数据库设计实例

    超大型系统的特点为: 1.处理的用户数一般都超过百万,有的还超过千万,数据库的数据量一般超过1TB: 2.系统必须提供实时响应功能,系统需不停机运行,要求系统有很高的可用性及可扩展性. 这篇是笔者针对 ...

  6. oracle报错数据复数,Oracle数据库设计策略及规范

    Oracle数据库设计策略及规范 设计策略及规范 1. 目的 定义Oracle数据库设计规范,作为数据库规划.设计.开发以及维护人员的技术参考资料.用以规范和指导相关人员的设计行为. 2. 概述 本文 ...

  7. Oracle数据库的乘号是什么,(Oracle数据库设计实验指导书yk.doc

    (Oracle数据库设计实验指导书yk Oracle数据库设计实验指导书 <Oracle 数据库设计>课程实验 一.本实验课在培养实验能力中的地位及作用 Oracle 数据库设计是软件工程 ...

  8. 数据库系统概论:第七章 数据库设计

    7.1 数据库设计概述 数据库设计,广义上讲,是数据库及其应用系统的设计,即设计整个数据库应用系统:狭义上讲,是设计数据库本身,即设计数据库的各级模式并建立数据库,这是数据库应用系统设计的一部分. 数 ...

  9. Oracle数据库设计(开放式基金交易平台)

    目录 项目实战1... 开放式基金交易平台(数据库设计) 1 1.1     需求描述... 1 1.2     问题分析... 1 1.3     相关技术与工具... 4 1.4     阶段划分 ...

最新文章

  1. nodejs写html文件路径,Nodejs读取文件时相对路径的正确写法(使用fs模块)
  2. BookMarklet:瑞士军刀你用了吗?
  3. 三种SQLServer分页查询语句笔记
  4. php列表框怎么用,PHP+Mysql+jQuery查询和列表框选择操作实例讲解
  5. c语言程序设计报告调试分析,C语言程序设计情况分析报告资料.doc
  6. Python高级——正则表达式与re模块
  7. jQuery获取隐藏文本域
  8. Spark共享变量(广播变量、累加器)
  9. +搭建“记忆宫殿”的三款思维导图神器
  10. 【JAVA】第十一届蓝桥杯省模拟赛答案(高职专科组)
  11. FragmentActivity_左右滑动的碎片
  12. mac os x 使用教程_如何在Mac OS X计算机上使用扫描仪
  13. Uva 167 The Sultan's Successors(dfs)
  14. 网络栈主要结构介绍(socket、sock、sk_buff,etc)
  15. 卡尔曼滤波系列——(四)无损卡尔曼滤波
  16. C# 对Excel表格中的数据进行排序
  17. HTML5代码学习:值得收藏的HTML5代码段
  18. 散装食品的经营之道,从哪方面入手?
  19. Mac电脑移动硬盘文件呈灰色,无法打开怎么办?
  20. 和嵌入式相关的一些python程序

热门文章

  1. 通过pipeline实现jenkins的ci/cd功能
  2. sql 脚本编写之路 常用语句(一) 1.用一个表中的某一列更新另外一个表的某些列:...
  3. 为什么写博客?如何在博客中更好的分享?
  4. JS实现的ajax和同源策略
  5. 201671010103 2016-2017-2 《Java程序设计》第十二周学习心得
  6. Wordpress: contact form 7 表单内容同行
  7. linux 单引号,双引号,反引号的小总结。
  8. 软件包 sun-java6-jdk 没有可供安装的候选者
  9. SQLServer数据库的备份/恢复的3中策略实例
  10. 爱因斯坦牛顿达尔文投胎中国后