搜索
高级检索
高级搜索
书       名 :
著       者 :
出  版  社 :
I  S  B  N:
文献来源:
出版时间 :
数据库设计解决方案入门经典
0.00    
图书来源: 浙江图书馆(由图书馆配书)
  • 配送范围:
    全国(除港澳台地区)
  • ISBN:
    9787302215967
  • 作      者:
    (美)Rod Stephens著
  • 出 版 社 :
    清华大学出版社
  • 出版日期:
    2010
收藏
内容介绍
  数据库在大多数企业或机构的运营中扮演着至关重要的角色;它们作为核心存储库,储存着产品、客户、供应商、销售等关键信息和其他大量的必备信息。毫无疑问的是,大部分商务计算都涉及数据库应用。
  本书向读者提供了许多实用的方法和工具,用来设计高效、可靠和安全的数据库。本书作者RodStephens详细讲解了应该如何组织数据库以便在不降低性能的前提下确保数据完整性,为开发各种数据库应用程序提供了坚实的基础。书中提到的方法和技术适刚厂各种数据库环境,包括Oracle、Microsoft Access、SQL Server和MySQL。通过学习本书,读者将会了解优秀数据库设计的基本过程并最终掌握实际设计数据库的方法。
  本书主要内容
  ·如何确定满足用户需求的数据库要求
  ·使用各种建模技术构建数据模型的方法,包括实体关系模型、用户界面模型和语义对象模型
  ·了解不同类型的数据库的技巧,包括关系数据库、FlatFiles、电子表格、XML和对象数据库
  ·如何优化和调整设计以便改善数据库的性能
  ·理解良好的应用程序设计和数据库设计之间关联的技术
  ·设计灵活、健壮的数据库方法以适应业务变化和发展
  ·便于维护和技术支持的设计方法
  ·避免常见的数据库设计错误的方法
  本书读者对象
  本书适用于需要学习设计、构建、分析和珲解数据库的所有读者,并且不要求读者具备数据库或程序设计的经验。
展开
精彩书摘
  ·只要存储的实际数据是一致的,那么所有这些数据库(除了大脑)都提供一致的结果。例如,使用相同笔记本的两个人会查找到相同的数据。类似地,如果随后查看同一个笔记本,它将显示与以前看到的数据相同的数据(前提是没有修改它)。
  ·所有这些数据库(除了档案柜)都是便携的。
  ·大脑可以执行复杂的计算,至少对于有限的类型和数字是这样的。
  ·所有这些数据库都提供原子事务处理(或交易)。
  最后一个优点比其他优点更为抽象一些,因此需要进行更多的说明。原子事务处理可能是一系列较为复杂的行动,那些不直接参与执行事务的人将它们看做是单一操作。
  最典型的示例是从一个银行账户向另一个账户转账。假定Alice向Bob开了一张价值100美元的支票,并且需要在他们的账户之间转移这笔钱。您拿起记账本从Alice的记录上扣除100美元并将100美元添加到Bob的记录上,然后放下笔记本。其他使用笔记本的人可能在事务处理之前(此时Alice有100美元)或事务处理之后(此时Bob有100美元)查看它,但是不能在从Alice账户上扣除100美元但还没有转给Bob的事务处理过程中查看它。当处理进行到一半时绝不允许办公室里粗鲁的同事从您的手中抢走笔记本,它是一种要么全做要么不做的事务处理。
  除了上述优点以外,诸如笔记本和档案柜这样的信息容器有一些缺点。研究这些缺点很有价值,这样一来便可以在构建计算机数据库时设法避免它们。
  下面的列表汇总了这些信息容器具有的一些缺点。
  ·所有这些数据库都可能保存不完整的、不正确的或自相矛盾的数据。
  ·一些数据库容易丢失或被盗。一些人可能会趁您吃午饭的时候窃取您的笔记本或者在公共汽车上从您的肩膀上偷看笔记本内容。另外,当匆忙赶航班时甚至可能把笔记本遗忘在安检柜台上。
  ·在所有这些数据库中,纠正数据中较大的差错可能较为困难。例如,可以在地址备忘录上使用钢笔更改某个人的地址。如果在您所在区域建造了一个新城市,则更新数百个地址要困难得多(这种情况最近发生在我的居住地附近)。这种情况需要对一摞名片、一本笔记本或档案柜进行冗长的搜索。而您的大脑彻底更新这种变化可能需要几年的时间。
  ·根据不可控的因素,如情绪、疲劳程度甚至是否饥饿,大脑会在不同的时间给出不同的结果。
  ·所有这些数据库都位于一个单独的地方,因此不能方便地共享它们。此外,每种数据库也不能方便地备份,如果原始的数据库丢失或破坏则会丢失数据。下一节考虑将上述优点和缺点转换成在计算机数据库中希望获得或避免的特性。
  1.4 理想的数据库特性
  通过了解物理数据库的优点和缺点,可以创建一个计算机数据库应该具有的特性列表。其中一些是所有数据库都必须具有的基本特性(应该能够从数据库中获取数据。
展开
目录
第Ⅰ部分 数据库和数据库设计介绍
第1章 有效数据库设计的目标
1.1 理解数据库设计的重要性
1.2 信息容器
1.3 信息容器的优缺点
1.4 理想的数据库特性
1.4.1 CRUD
1.4.2 检索
1.4.3 一致性
1.4.4 有效性(验证)
1.4.5 轻松的纠错
1.4.6 速度
1.4.7 原子事务处理
1.4.8 ACID
1.4.9 持久性和备份
1.4.10 低成本和可扩充性
1.4.11 易用性
1.4.12 便携性
1.4.13 安全性
1.4.14 共享
1.4.15 执行复杂计算的能力
1.4.16 良好设计和拙劣设计对应的结果
1.5 本章小结
1.6 练习

第2章 数据库类型
2.1 为何多此一举
2.2 平面文件
2.2.1 INI文件
2.2.2 Windows系统注册表
2.3 关系数据库
2.4 电子数据表
2.5 分级数据库
2.6 XML
2.6.1 XML基础知识
2.6.2 XML结构
2.6.3 XML小结
2.7 网络
2.8 对象
2.9 对象关系
2.10 特殊类型的数据库
2.10.1 面向文档的数据库
2.10.2 演绎数据库
2.10.3 维度(或空间)数据库
2.10.4 时态数据库
2.11 本章小结
2.12 练习

第3章 关系数据库基础知识
3.1 关系视角
3.2 表、行和列
3.3 关系、属性和元组
3.4 键
3.5 索引
3.6 约束
3.6.1 基本约束
3.6.2 检查约束
3.6.3 主键约束
3.6.4.唯一(性)约束
3.6.5 外键约束
3.7 数据库操作
3.8 本章小结
3.9 练习

第Ⅱ部分 数据库设计过程和技术
第4章 了解用户需求
4.1 制定计划
4.2 拿出一个问题清单
4.2.1 功能
4.2.2 数据需求
4.2.3 数据完整性
4.2.4 安全性
4.2.5 环境
4.3 与客户会面
4.4 了解重要人物
4.5 向客户请教
4.6 设身处地为用户着想
4.7 调研现行业务
4.8 集体讨论
4.9 考虑未来
4.10 搞清客户的思维过程
4.11 了解客户真正的需求
4.12 区分优先次序
4.13 证实了解的情况
4.14 撰写需求文档
4.15 编制用例
4.16 确定可行性
4.17 本章小结
4.18 练习

第5章 将用户需求转换成数据模型
5.1 数据模型的概念
5.2 用户界面模型
5.3 语义对象模型
5.3.1 类和对象
5.3.2 基数
5.3.3 标识符
5.3.4 合在一起
5.3.5 语义视图
5.3.6 类的类型
5.3.7 评论与注释
5.4 实体关系模型
5.4.1 实体、属性和标识符
5.4.2 关系
5.4.3 基数
5.4.4 继承
5.4.5 补充约定
5.4.6 评论和注释
5.5 关系模型
5.5.1 转换语义对象模型
5.5.2 转换ER图
5.6 本章小结
5.7 练习

第6章 提取业务规则
6.1 业务规则的概念
6.2 识别重要的业务规则
6.3 提取重要的业务规则
6.4 多层应用程序
6.5 本章小结
6.6 练习

第7章 规范化数据
7.1 规范化的概念
7.2 第一范式(INF)
7.3 第二范式(2NF)
7.4 第三范式(3NF)
7.5 止步于第三范式
7.6 Boyce.Codd范式(BCNF)
7.7 第四范式(4NF)
7.8 第五范式(5NF)
7.9 域/键范式(DKNF)
7.10 必要的冗余
7.11 最佳的规范化级别
7.12 本章小结
7.13 练习

第8章 设计数据库以支持软件应用程序
8.1 提前规划
8.2 将所有事项记录在案
8.3 考虑多层体系结构
8.4 将域转换成表
8.5 重视表
8.6 使用三种表
8.7 使用命名约定
8.8 允许冗余数据
8.9 不要包罗万象
8.10 本章小结
8.11 练习

第9章 常见的设计模式
9.1 关联
9.1.1 多对多关联
9.1.2 多个多对多关联
9.1.3 多对象关联
9.1.4 重复的属性关联
9.1.5 自反关联
9.2 时间数据
9.2.1 有效日期
9.2.2 被删除的对象
9.2.3 时效化部分数据
9.3 事件记录和锁定
9.3.1 审计跟踪
9.3.2 全程记录
9.4 本章小结
9.5 练习

第10章 常见的设计陷阱
10.1 缺乏准备
10.2 拙劣的文档编制
10.3 拙劣的命名标准
10.4 欠缺思考
10.5 没有考虑变化
10.6 规范化泛滥
10.7 规范化不足
10.8 测试不够
10.9 过分担忧性能
10.10 把表混杂在一起
10.11 不强制执行约束
10.12 对ID感到困扰
10.13 没有定义自然键
10.14 本章小结
10.15 练习

第Ⅲ部分 详尽的案例分析
第11章 用户需要和要求
11.1 满足客户需求
11.2 了解客户的想法
11.2.1 确定系统应该实现的功能
11.2.2 确定项目应该呈现的样式
11.2.3 确定用户界面需要的数据
11.2.4 确定数据的来源
11.2.5 确定数据段关联的方式
11.2.6 决定性能需求
11.2.7 确定安全需求
11.2.8 确定数据完整性要求
1l.3 编写用例
11.4 编写需求文档
11.5 要求反馈
11.6 本章小结
11.7 练习

第12章 构建数据模型
12.1 语义对象模型
12.1.1 构建初始的语义对象模型
12.1.2 改进语义对象模型
12.2 实体关系建模
12.2.1 构建ER图
12.2.2 构建组合ER图
12.2.3 改进实体关系图
12.3 关系建模
12.4 将所有关系整合在一起
12.5 本章小结
12.6 练习

第13章 提取业务规则
13.1 识别业务规则
13.1.1 Courses
13.1.2 CustomerCourses
13.1.3 Customers
13.1.4 Pets
13.1.5 Employees
13.1.6 Orders
13.1.7 Orderltems
13.1.8 Inventoryltems
13.1.9 TimeEntries
13.1.10 Shifts
13.1.11 Persons
13.1.12 Phones
13.1.13 Vendors
13.2 绘制新的关系模型
13.3 本章小结
13.4 练习

第14章 规范化和优化
14.1 提高灵活性
14.2 验证第一范式
14.3 验证第二范式
14.3.1 Pets
14.3.2 TimeEntries
14.4 验证第三范式
14.5 本章小结
14.6 练习

第Ⅳ部分 实现数据库(以Access和MySQL中的示例为例讲解)
第15章 MIcrosolftAccess
15.1 了解Access
15.2 启动Access
15.3 定义关系
15.4 创建字段约束
15.5 创建表约束
15.6 创建查询
15.6.1 查询设计视图
15.6.2 SQL视图
15.7 本章小结
15.8 练习

第16章 MySQL
16.1 安装MySQL
16.2 使用MySQL命令行客户端
16.3 执行SQL脚本
16.4 使用MySQL QueryBrowser
16.4.1 执行查询
16.4.2 编辑数据
16.4.3 创建并修改数据库
16.4.4 使用脚本
16.4.5 获取语法帮助
16.5 使用MySQL workbench
16.5.1 加载脚本
16.5.2 创建EER图
16.5.3 编辑数据库
16.5.4 定义触发器
16.5.5 导出脚本
16.6 本章小结
16.7 练习

第V部分 高级主题
第17章 SQL简介
17.1 背景介绍
17.2 获取更多的信息
17.3 标准
17.4 基本的语法
17.5 命令概述
17.6 CREATETABLE
17.7 CREATEINDEX
17.8 DROP
17.9 INSERT
17.10 SELECT
17.10.1 SELECT子句
17.10.2 FROM子句
17.10.3 WHERE子句
17.10.4 GROUPBY子句
17.10.5 ORDERBY子句
17.11 UPDATE子句
17.12 DELETE语句
17.13 本章小结
17.14 练习

第18章 使用SQL脚本来构建数据库
18.1 使用脚本的原因
18.2 脚本分类
18.2.1 数据库创建脚本
18.2.2 基本的初始化脚本
18.2.3 数据初始化脚本
18.2.4 清理脚本
18.2.5 保存脚本
18.3 整理SQL命令的次序
18.4 本章小结
18.5 练习

第19章 数据库维护
19.1 备份
19.2 数据仓库
19.3 修复数据库
19.4 压缩数据库
19.5 性能调整
19.6 本章小结
19.7 练习

第20章 数据库安全
20.1 适当的安全性级别
20.2 口令
20.2.1 单口令数据库
20.2.2 个人口令
20.2.3 操作系统口令
20.2.4 好的口令
20.3 权限
20.4 初始的配置和权限
20.5 过多的安全性
20.6 物理安全
20.7 本章小结
20.8 练习
附录A 练习题答案
附录B 数据库设计样例
术语表
展开
加入书架成功!
收藏图书成功!
我知道了(3)
发表书评
读者登录

请选择您读者所在的图书馆

选择图书馆
浙江图书馆
点击获取验证码
登录
没有读者证?在线办证