- 浏览: 582704 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
小网客:
噱头 没实际意义
【互动出版网】11.11购物狂欢节重磅大促,免费领万千优惠券 -
tongchuang123:
这是要出书了吗:o
微信控 控微信 -
韶华无限:
这也可以出本书……
玩转微信(彩印) -
zhukewen_java:
无语了。。。哪天出本《玩转QQ》?
玩转微信(彩印) -
yaying:
我只见过MySQL Cookbook中文版
jQuery Cookbook中文版
数据库书籍-数据库系统概念(原书第6版)
基本信息
- 原书名: Database System Concepts,Sixth Edition
- 原出版社: McGraw-Hill
- 作者: (美)Abraham Silberschatz Henry F.Korth S.Sudarshan
- 译者: 杨冬青 李红燕 唐世渭
- 丛书名: 计算机科学丛书
- 出版社:机械工业出版社
- ISBN:9787111375296
- 上架时间:2012-4-5
- 出版日期:2012 年3月
- 页码:804
- 定价 :¥99.00
- 会员价 : ¥69.30(70折)
- 校园优惠价 :¥69.3(70折)
http://product.china-pub.com/199151&iteye
内容简介
《数据库系统概念(原书第6版)》是经典的数据库系统教科书《database system concepts》的最新修订版,全面介绍数据库系统的各种知识,透彻阐释数据库管理的基本概念。本书内容丰富,不计算机书籍仅讨论了关系数据模型和关系语言、数据库设计过程、关系数据库理论、数据库应用设计和开发、数据存储结构、数据存取技术、查询优化方法、事务处理系统和并发控制、故障恢复技术、数据仓库和数据挖掘,而且对性能调整、性能评测标准、数据库应用测试和标准化、空间和地理数据、时间数据、多媒体数据、移动和个人数据库管理以及事务处理监控器、事务工作流、电子商务、高性能事务系统、实时事务系统和持续长时间的事务等高级应用主题进行了广泛讨论。
《数据库系统概念(原书第6版)》既可作为高年级本科生或低年级研究生的数据库课程教材,也可供数据库领域的技术人员参考。
《数据库系统概念(原书第6版)》既可作为高年级本科生或低年级研究生的数据库课程教材,也可供数据库领域的技术人员参考。
目录
《数据库系统概念(原书第6版)》
出版者的话
译者序
前言
第1章引言
1.1数据库系统的应用
1.2数据库系统的目标
1.3数据视图
1.3.1数据抽象
1.3.2实例和模式
1.3.3数据模型
1.4数据库语言
1.4.1数据操纵语言
1.4.2数据定义语言
1.5关系数据库
1.5.1表
1.5.2数据操纵语言
1.5.3数据定义语言
1.5.4来自应用程序的数据库访问
1.6数据库设计
出版者的话
译者序
前言
第1章引言
1.1数据库系统的应用
1.2数据库系统的目标
1.3数据视图
1.3.1数据抽象
1.3.2实例和模式
1.3.3数据模型
1.4数据库语言
1.4.1数据操纵语言
1.4.2数据定义语言
1.5关系数据库
1.5.1表
1.5.2数据操纵语言
1.5.3数据定义语言
1.5.4来自应用程序的数据库访问
1.6数据库设计
.1.6.1设计过程
1.6.2大学机构的数据库设计
1.6.3实体-联系模型
1.6.4规范化
1.7数据存储和查询
1.7.1存储管理器
1.7.2查询处理器
1.8事务管理
1.9数据库体系结构
1.10数据挖掘与信息检索
1.11特种数据库
1.11.1基于对象的数据模型
1.11.2半结构化数据模型
1.12数据库用户和管理员
1.12.1数据库用户和用户界面
1.12.2数据库管理员
1.13数据库系统的历史
1.14总结
术语回顾
实践习题
习题
工具
文献注解
第一部分关系数据库
第2章关系模型介绍
2.1关系数据库的结构
2.2数据库模式
2.3码
2.4模式图
2.5关系查询语言
2.6关系运算
2.7总结
术语回顾
实践习题
习题
文献注解
第3章sql
3.1sql查询语言概览
3.2sql数据定义
3.2.1基本类型
3.2.2基本模式定义
3.3sql查询的基本结构
3.3.1单关系查询
3.3.2多关系查询
3.3.3自然连接
3.4附加的基本运算
3.4.1更名运算
3.4.2字符串运算
3.4.3select子句中的属性说明
3.4.4排列元组的显示次序
3.4.5where子句谓词
3.5集合运算
3.5.1并运算
3.5.2交运算
3.5.3差运算
3.6空值
3.7聚集函数
3.7.1基本聚集
3.7.2分组聚集
3.7.3having子句
3.7.4对空值和布尔值的聚集
3.8嵌套子查询
3.8.1集合成员资格
3.8.2集合的比较
3.8.3空关系测试
3.8.4重复元组存在性测试
3.8.5from子句中的子查询
3.8.6with子句
3.8.7标量子查询
3.9数据库的修改
3.9.1删除
3.9.2插入
3.9.3更新
3.10总结
术语回顾
实践习题
习题
工具
文献注解
第4章中级sql
4.1连接表达式
4.1.1连接条件
4.1.2外连接
4.1.3连接类型和条件
4.2视图
4.2.1视图定义
4.2.2sql查询中使用视图
4.2.3物化视图
4.2.4视图更新
4.3事务
4.4完整性约束
4.4.1单个关系上的约束
4.4.2not null约束
4.4.3unique约束
4.4.4check子句
4.4.5参照完整性
4.4.6事务中对完整性约束的违反
4.4.7复杂check条件与断言
4.5sql的数据类型与模式
4.5.1sql中的日期和时间类型
4.5.2默认值
4.5.3创建索引
4.5.4大对象类型
4.5.5用户定义的类型
4.5.6create table的扩展
4.5.7模式、目录与环境
4.6授权
4.6.1权限的授予与收回
4.6.2角色
4.6.3视图的授权
4.6.4模式的授权
4.6.5权限的转移
4.6.6权限的收回
4.7总结
术语回顾
实践习题
习题
文献注解
第5章高级sql
5.1使用程序设计语言访问数据库
5.1.1jdbc
5.1.2odbc
5.1.3嵌入式sql
5.2函数和过程
5.2.1声明和调用sql函数和过程
5.2.2支持过程和函数的语言构造
5.2.3外部语言过程
5.3触发器
5.3.1对触发器的需求
5.3.2sql中的触发器
5.3.3何时不用触发器
5.4递归查询**
5.4.1用迭代来计算传递闭包
5.4.2sql中的递归
5.5高级聚集特性**
5.5.1排名
5.5.2分窗
5.6olap**
5.6.1联机分析处理
5.6.2交叉表与关系表
5.6.3sql中的olap
5.7总结
术语回顾
实践习题
习题
工具
文献注解
第6章形式化关系查询语言
6.1关系代数
6.1.1基本运算
6.1.2关系代数的形式化定义
6.1.3附加的关系代数运算
6.1.4扩展的关系代数运算
6.2元组关系演算
6.2.1查询示例
6.2.2形式化定义
6.2.3表达式的安全性
6.2.4语言的表达能力
6.3域关系演算
6.3.1形式化定义
6.3.2查询的例子
6.3.3表达式的安全性
6.3.4语言的表达能力
6.4总结
术语回顾
实践习题
习题
文献注解
第二部分数据库设计
第7章数据库设计和er模型
7.1设计过程概览
7.1.1设计阶段
7.1.2设计选择
7.2实体-联系模型
7.2.1实体集
7.2.2联系集
7.2.3属性
7.3约束
7.3.1映射基数
7.3.2参与约束
7.3.3码
7.4从实体集中删除冗余属性
7.5实体-联系图
7.5.1基本结构
7.5.2映射基数
7.5.3复杂的属性
7.5.4角色
7.5.5非二元的联系集
7.5.6弱实体集
7.5.7大学的er图
7.6转换为关系模式
7.6.1具有简单属性的强实体集的表示
7.6.2具有复杂属性的强实体集的表示
7.6.3弱实体集的表示
7.6.4联系集的表示
7.7实体-联系设计问题
7.7.1用实体集还是用属性
7.7.2用实体集还是用联系集
7.7.3二元还是n元联系集
7.7.4联系属性的布局
7.8扩展的er特性
7.8.1特化
7.8.2概化
7.8.3属性继承
7.8.4概化上的约束
7.8.5聚集
7.8.6转换为关系模式
7.9数据建模的其他表示法
7.9.1er图的其他表示法
7.9.2统一建模语言uml
7.10数据库设计的其他方面
7.10.1数据约束和关系数据库设计
7.10.2使用需求:查询、性能
7.10.3授权需求
7.10.4数据流、工作流
7.10.5数据库设计的其他问题
7.11总结
术语回顾
实践习题
习题
工具
文献注解
第8章关系数据库设计
8.1好的关系设计的特点
8.1.1设计选择:更大的模式
8.1.2设计选择:更小的模式
8.2原子域和第一范式
8.3使用函数依赖进行分解
8.3.1码和函数依赖
8.3.2boycecodd范式
8.3.3bcnf和保持依赖
8.3.4第三范式
8.3.5更高的范式
8.4函数依赖理论
8.4.1函数依赖集的闭包
8.4.2属性集的闭包
8.4.3正则覆盖
8.4.4无损分解
8.4.5保持依赖
8.5分解算法
8.5.1bcnf分解
8.5.23nf分解
8.5.33nf算法的正确性
8.5.4bcnf和3nf的比较
8.6使用多值依赖的分解
8.6.1多值依赖
8.6.2第四范式
8.6.34nf分解
8.7更多的范式
8.8数据库设计过程
8.8.1er模型和规范化
8.8.2属性和联系的命名
8.8.3为了性能去规范化
8.8.4其他设计问题
8.9时态数据建模
8.10总结
术语回顾
实践习题
习题
文献注解
第9章应用设计和开发
9.1应用程序和用户界面
9.2web基础
9.2.1统一资源定位符
9.2.2超文本标记语言
9.2.3web服务器和会话
9.3servlet和jsp
9.3.1一个servlet的例子
9.3.2servlet会话
9.3.3servlet的生命周期
9.3.4servlet支持
9.3.5服务器端脚本
9.3.6客户端脚本
9.4应用架构
9.4.1业务逻辑层
9.4.2数据访问层和对象-关系映射
9.4.3web服务
9.4.4断连操作
9.5快速应用开发
9.5.1构建用户界面的工具
9.5.2web应用框架
9.5.3报表生成器
9.6应用程序性能
9.6.1利用缓存减少开销
9.6.2并行处理
9.7应用程序安全性
9.7.1sql注入
9.7.2跨站点脚本和请求伪造
9.7.3密码泄露
9.7.4应用程序认证
9.7.5应用级授权
9.7.6审计追踪
9.7.7隐私
9.8加密及其应用
9.8.1加密技术
9.8.2数据库中的加密支持
9.8.3加密和认证
9.9总结
术语回顾
实践习题
习题
项目建议
工具
文献注解
第三部分数据存储和查询
第10章存储和文件结构
10.1物理存储介质概述
10.2磁盘和快闪存储器
10.2.1磁盘的物理特性
10.2.2磁盘性能的度量
10.2.3磁盘块访问的优化
10.2.4快闪存储
10.3raid
10.3.1通过冗余提高可靠性
10.3.2通过并行提高性能
10.3.3raid级别
10.3.4raid级别的选择
10.3.5硬件问题
10.3.6其他的raid应用
10.4第三级存储
10.4.1光盘
10.4.2磁带
10.5文件组织
10.5.1定长记录
10.5.2变长记录
10.6文件中记录的组织
10.6.1顺序文件组织
10.6.2多表聚簇文件组织
10.7数据字典存储
10.8数据库缓冲区
10.8.1缓冲区管理器
10.8.2缓冲区替换策略
10.9总结
术语回顾
实践习题
习题
文献注解
第11章索引与散列
11.1基本概念
11.2顺序索引
11.2.1稠密索引和稀疏索引
11.2.2多级索引
11.2.3索引的更新
11.2.4辅助索引
11.2.5多码上的索引
11.3b+树索引文件
11.3.1b+树的结构
11.3.2b+树的查询
11.3.3b+树的更新
11.3.4不唯一的搜索码
11.3.5b+树更新的复杂性
11.4b+树扩展
11.4.1b+树文件组织
11.4.2辅助索引和记录重定位
11.4.3字符串上的索引
11.4.4b+树索引的批量加载
11.4.5b树索引文件
11.4.6闪存
11.5多码访问
11.5.1使用多个单码索引
11.5.2多码索引
11.5.3覆盖索引
11.6静态散列
11.6.1散列函数
11.6.2桶溢出处理
11.6.3散列索引
11.7动态散列
11.7.1数据结构
11.7.2查询和更新
11.7.3静态散列与动态散列比较
11.8顺序索引和散列的比较
11.9位图索引
11.9.1位图索引结构
11.9.2位图操作的高效实现
11.9.3位图和b+树
11.10sql中的索引定义
11.11总结
术语回顾
实践习题
习题
文献注解
第12章查询处理
12.1概述
12.2查询代价的度量
12.3选择运算
12.3.1使用文件扫描和索引的选择
12.3.2涉及比较的选择
12.3.3复杂选择的实现
12.4排序
12.4.1外部排序归并算法
12.4.2外部排序归并的代价分析
12.5连接运算
12.5.1嵌套循环连接
12.5.2块嵌套循环连接
12.5.3索引嵌套循环连接
12.5.4归并连接
12.5.5散列连接
12.6其他运算
12.6.1去除重复
12.6.2投影
12.6.3集合运算
12.6.4外连接
12.6.5聚集
12.7表达式计算
12.7.1物化
12.7.2流水线
12.8总结
术语回顾
实践习题
习题
文献注解
第13章查询优化
13.1概述
13.2关系表达式的转换
13.2.1等价规则
13.2.2转换的例子
13.2.3连接的次序
13.2.4等价表达式的枚举
13.3表达式结果集统计大小的估计
13.3.1目录信息
13.3.2选择运算结果大小的估计
13.3.3连接运算结果大小的估计
13.3.4其他运算的结果集大小的估计
13.3.5不同取值个数的估计
13.4执行计划选择
13.4.1基于代价的连接顺序选择
13.4.2采用等价规则的基于代价的优化器
13.4.3启发式优化
13.4.4嵌套子查询的优化**
13.5物化视图**
13.5.1视图维护
13.5.2增量的视图维护
13.5.3查询优化和物化视图
13.5.4物化视图和索引选择
13.6查询优化中的高级话题**
13.6.1topk优化
13.6.2连接极小化
13.6.3更新的优化
13.6.4多查询优化和共享式扫描
13.6.5参数化查询优化
13.7总结
术语回顾
实践习题
习题
文献注解
第四部分事务管理
第14章事务
14.1事务概念
14.2一个简单的事务模型
14.3存储结构
14.4事务原子性和持久性
14.5事务隔离性
14.6可串行化
14.7事务隔离性和原子性
14.7.1可恢复调度
14.7.2无级联调度
14.8事务隔离性级别
14.9隔离性级别的实现
14.9.1锁
14.9.2时间戳
14.9.3多版本和快照隔离
14.10事务的sql语句表示
14.11总结
术语回顾
实践习题
习题
文献注解
第15章并发控制
15.1基于锁的协议
15.1.1锁
15.1.2锁的授予
15.1.3两阶段封锁协议
15.1.4封锁的实现
15.1.5基于图的协议
15.2死锁处理
15.2.1死锁预防
15.2.2死锁检测与恢复
15.3多粒度
15.4基于时间戳的协议
15.4.1时间戳
15.4.2时间戳排序协议
15.4.3thomas写规则
15.5基于有效性检查的协议
15.6多版本机制
15.6.1多版本时间戳排序
15.6.2多版本两阶段封锁
15.7快照隔离
15.7.1更新事务的有效性检验步骤
15.7.2串行化问题
15.8插入操作、删除操作与谓词读
15.8.1删除
15.8.2插入
15.8.3谓词读和幻象现象
15.9实践中的弱一致性级别
15.9.1二级一致性
15.9.2游标稳定性
15.9.3跨越用户交互的并发控制
15.10索引结构中的并发**
15.11总结
术语回顾
实践习题
习题
文献注解
第16章恢复系统
16.1故障分类
16.2存储器
16.2.1稳定存储器的实现
16.2.2数据访问
16.3恢复与原子性
16.3.1日志记录
16.3.2数据库修改
16.3.3并发控制和恢复
16.3.4事务提交
16.3.5使用日志来重做和撤销事务
16.3.6检查点
16.4恢复算法
16.4.1事务回滚
16.4.2系统崩溃后的恢复
16.5缓冲区管理
16.5.1日志记录缓冲
16.5.2数据库缓冲
16.5.3操作系统在缓冲区管理中的作用
16.5.4模糊检查点
16.6非易失性存储器数据丢失的故障
16.7锁的提前释放和逻辑undo操作
16.7.1逻辑操作
16.7.2逻辑undo日志记录
16.7.3有逻辑undo的事务回滚
16.7.4逻辑undo中的并发问题
16.8aries**
16.8.1数据结构
16.8.2恢复算法
16.8.3其他特性
16.9远程备份系统
16.10总结
术语回顾
实践习题
习题
文献注解
第五部分系统体系结构
第17章数据库系统体系结构
17.1集中式与客户-服务器体系结构
17.1.1集中式系统
17.1.2客户-服务器系统
17.2服务器系统体系结构
17.2.1事务服务器
17.2.2数据服务器
17.2.3基于云的服务器
17.3并行系统
17.3.1加速比和扩展比
17.3.2互连网络
17.3.3并行数据库体系结构
17.4分布式系统
17.4.1分布式数据库示例
17.4.2实现问题
17.5网络类型
17.5.1局域网
17.5.2广域网
17.6总结
术语回顾
实践习题
习题
文献注解
第18章并行数据库
18.1引言
18.2i/o并行
18.2.1划分技术
18.2.2划分技术比较
18.2.3偏斜处理
18.3查询间并行
18.4查询内并行
18.5操作内并行
18.5.1并行排序
18.5.2并行连接
18.5.3其他关系运算
18.5.4运算的并行计算代价
18.6操作间并行
18.6.1流水线并行
18.6.2独立并行
18.7查询优化
18.8并行系统设计
18.9多核处理器的并行性
18.9.1并行性与原始速度
18.9.2高速缓冲存储器和多线程
18.9.3适应现代体系架构的数据库系统设计
18.10总结
术语回顾
实践习题
习题
文献注解
第19章分布式数据库
19.1同构和异构数据库
19.2分布式数据存储
19.2.1数据复制
19.2.2数据分片
19.2.3透明性
19.3分布式事务
19.3.1系统结构
19.3.2系统故障模式
19.4提交协议
19.4.1两阶段提交
19.4.2三阶段提交
19.4.3事务处理的可选择性模型
19.5分布式数据库中的并发控制
19.5.1封锁协议
19.5.2时间戳
19.5.3弱一致性级别的复制
19.5.4死锁处理
19.6可用性
19.6.1基于多数的方法
19.6.2读一个、写所有可用的方法
19.6.3站点重建
19.6.4与远程备份的比较
19.6.5协调器的选择
19.6.6为可用性而牺牲一致性
19.7分布式查询处理
19.7.1查询转换
19.7.2简单的连接处理
19.7.3半连接策略
19.7.4利用并行性的连接策略
19.8异构分布式数据库
19.8.1数据统一视图
19.8.2查询处理
19.8.3多数据库中的事务管理
19.9基于云的数据库
19.9.1云上的数据存储系统
19.9.2云上的传统数据库
19.9.3基于云的数据库的挑战
19.10目录系统
19.10.1目录访问协议
19.10.2ldap:轻量级目录访问协议
19.11总结
术语回顾
实践习题
习题
文献注解
第六部分数据仓库、数据挖掘与信息检索
第20章数据仓库与数据挖掘
20.1决策支持系统
20.2数据仓库
20.2.1数据仓库成分
20.2.2数据仓库模式
20.2.3面向列的存储
20.3数据挖掘
20.4分类
20.4.1决策树分类器
20.4.2其他类型的分类器
20.4.3回归
20.4.4分类器验证
20.5关联规则
20.6其他类型的关联
20.7聚类
20.8其他类型的数据挖掘
20.9总结
术语回顾
实践习题
习题
工具
文献注解
第21章信息检索
21.1概述
21.2使用术语的相关性排名
21.2.1使用tfidf的排名方法
21.2.2基于相似性的检索
21.3使用超链接的相关性
21.3.1流行度排名
21.3.2pagerank
21.3.3其他的流行度度量
21.3.4搜索引擎
21.3.5将tfidf和流行度排名度量方法结合
21.4同义词、多义词和本体
21.5文档的索引
21.6检索的有效性度量
21.7web的抓取和索引
21.8信息检索:网页排名之外
21.8.1查询结果的多样化
21.8.2信息抽取
21.8.3问答系统
21.8.4查询结构化数据
21.9目录与分类
21.10总结
术语回顾
实践习题
习题
工具
文献注解
第七部分特种数据库
第22章基于对象的数据库
22.1概述
22.2复杂数据类型
22.3sql中的结构类型和继承
22.3.1结构类型
22.3.2类型继承
22.4表继承
22.5sql中的数组和多重集合类型
22.5.1创建和访问集合体值
2.5.2查询以集合体为值的属性
22.5.3嵌套和解除嵌套
22.6sql中的对象标识和引用类型
22.7or特性的实现
22.8持久化程序设计语言
22.8.1对象的持久化
22.8.2对象标识和指针
22.8.3持久对象的存储和访问
22.8.4持久化c++系统
22.8.5持久化java系统
22.9对象-关系映射
22.10面向对象与对象-关系
22.11总结
术语回顾
实践习题
习题
工具
文献注解
第23章xml
23.1动机
23.2xml数据结构
23.3xml文档模式
23.3.1文档类型定义
23.3.2xml schema
23.4查询和转换
23.4.1xml树模型
23.4.2xpath
23.4.3xquery
23.5xml应用程序接口
23.6xml数据存储
23.6.1非关系的数据存储
23.6.2关系数据库
23.6.3sql/xml
23.7xml应用
23.7.1存储复杂结构数据
23.7.2标准化数据交换格式
23.7.3web服务
23.7.4数据中介
23.8总结
术语回顾
实践习题
习题
工具
文献注解
第八部分高级主题
第24章高级应用开发
24.1性能调整
24.1.1提高面向集合的特性
24.1.2批量加载和更新的调整
24.1.3瓶颈位置
24.1.4可调参数
24.1.5硬件调整
24.1.6模式调整
24.1.7索引调整
24.1.8使用物化视图
24.1.9物理设计的自动调整
24.1.10并发事务调整
24.1.11性能模拟
24.2性能基准程序
24.2.1任务集
24.2.2数据库应用类型
24.2.3tpc基准程序
24.3应用系统开发的其他问题
24.3.1应用系统测试
24.3.2应用系统移植
24.4标准化
24.4.1sql标准
24.4.2数据库连接标准
24.4.3对象数据库标准
24.4.4基于xml的标准
24.5总结
术语回顾
实践习题
习题
文献注解
第25章时空数据和移动性
25.1动机
25.2数据库中的时间
25.2.1sql中的时间规范
25.2.2时态查询语言
25.3空间与地理数据
25.3.1几何信息表示
25.3.2设计数据库
25.3.3地理数据
25.3.4空间查询
25.3.5空间数据的索引
25.4多媒体数据库
25.4.1多媒体数据格式
25.4.2连续媒体数据
25.4.3基于相似性的检索
25.5移动性和个人数据库
25.5.1移动计算模型
25.5.2路由和查询处理
25.5.3广播数据
25.5.4连接断开与一致性
25.6总结
术语回顾
实践习题
习题
文献注解
26章高级事务处理
26.1事务处理监控器
26.1.1tp监控器体系结构
26.1.2使用tp监控器进行应用协调
26.2事务工作流
26.2.1工作流说明
26.2.2工作流的故障原子性需求
26.2.3工作流执行
26.2.4工作流恢复
26.2.5工作流管理系统
26.3电子商务
26.3.1电子目录
26.3.2市场
26.3.3订单结算
26.4主存数据库
26.5实时事务系统
26.6长事务
26.6.1不可串行化的执行
26.6.2并发控制
26.6.3嵌套事务和多级事务
26.6.4补偿事务
26.6.5实现问题
26.7总结
术语回顾
实践习题
习题
文献注解
第九部分实例研究
第27章postgresql
27.1概述
27.2用户界面
27.2.1交互式终端界面
27.2.2图形界面
27.2.3编程语言接口
27.3sql变化和扩展
27.3.1postgresql类型
27.3.2规则和其他主动数据库特征
27.3.3可扩展性
27.4postgresql中的事务管理
27.4.1postgresql的并发控制
27.4.2恢复
27.5存储和索引
27.5.1表
27.5.2索引
27.6查询处理和优化
27.6.1查询重写
27.6.2查询规划和优化
27.6.3查询执行器
27.6.4触发器和约束
27.7系统结构
文献注解
第28章oracle
28.1数据库设计和查询工具
28.1.1数据库和应用设计工具
28.1.2查询工具
28.2sql的变化和扩展
28.2.1对象-关系特性
28.2.2oracle xml db
28.2.3过程化语言
28.2.4维度
28.2.5联机分析处理
28.2.6触发器
28.3存储和索引
28.3.1表空间
28.3.2段
28.3.3表
28.3.4索引
28.3.5位图索引
28.3.6基于函数的索引
28.3.7连接索引
28.3.8域索引
28.3.9划分
28.3.10物化视图
28.4查询处理和优化
28.4.1执行方法
28.4.2优化
28.4.3并行执行
28.4.4结果高速缓存
28.5并发控制与恢复
28.5.1并发控制
28.5.2恢复的基本结构
28.5.3oracle数据卫士
28.6系统体系结构
28.6.1专用服务器:内存结构
28.6.2专用服务器:进程结构
28.6.3共享服务器
28.6.4oracle real application clusters
28.6.5自动存储管理器
28.6.6oracle exadata
28.7复制、分布以及外部数据
28.7.1复制
28.7.2分布式数据库
28.7.3外部数据源
28.8数据库管理工具
28.8.1oracle企业管理器
28.8.2自动工作负载存储
28.8.3数据库资源管理
28.9数据挖掘
文献注解
第29章ibm db2 universal database
29.1概述
29.2数据库设计工具
29.3sql的变化和扩展
29.3.1xml特性
29.3.2数据类型的支持
29.3.3用户自定义函数和方法
29.3.4大对象
29.3.5索引扩展和约束
29.3.6web服务
29.3.7其他特性
29.4存储和索引
29.4.1存储体系结构
29.4.2缓冲池
29.4.3表、记录和索引
29.5多维聚簇
29.5.1块索引
29.5.2块映射
29.5.3设计考虑
29.5.4对现有技术的影响
29.6查询处理和优化
29.6.1存取方法
29.6.2连接、聚集和集合运算
29.6.3对复杂sql处理的支持
29.6.4多处理器查询处理特性
29.6.5查询优化
29.7物化的查询表
29.7.1查询路由到mqt
29.7.2mqt的维护
29.8db2中的自治特性
29.8.1配置
29.8.2优化
29.9工具和实用程序
29.10并发控制和恢复
29.10.1并发与隔离
29.10.2提交与回滚
29.10.3日志与恢复
29.11系统体系结构
29.12复制、分布和外部数据
29.13商务智能特性
文献注解
30章microsoft sql server
30.1管理、设计和查询工具
30.1.1数据库开发和可视化数据库工具
30.1.2数据库查询和调优工具
30.1.3sql server management studio
30.2sql变化和扩展
30.2.1数据类型
30.2.2查询语言增强
30.2.3例程
30.2.4带过滤的索引
30.3存储和索引
30.3.1文件组
30.3.2文件组内的空间管理
30.3.3表
30.3.4索引
30.3.5分区
30.3.6在线创建索引
30.3.7扫描和预读
30.3.8压缩
30.4查询处理和优化
30.4.1编译处理概述
30.4.2查询简化
30.4.3重排序和基于代价的优化
30.4.4更新计划
30.4.5优化时的数据分析
30.4.6部分搜索和启发式搜索
30.4.7查询执行
30.5并发与恢复
30.5.1事务
30.5.2封锁
30.5.3恢复和可用性
30.6系统体系结构
30.6.1服务器上的线程池
30.6.2内存管理
30.6.3安全性
30.7数据访问
30.8分布式异构查询处理
30.9复制
30.9.1复制模型
30.9.2复制选项
30.10.net中的服务器编程
30.10.1.net基本概念
30.10.2sql clr宿主
30.10.3可扩展性协定
30.11xml支持
30.11.1本地存储和组织xml
30.11.2查询和更新xml数据类型
30.11.3xquery表达式的执行
30.12sql server服务代理
30.13商务智能
30.13.1sql server集成服务
30.13.2sql server分析服务
30.13.3sql server报表服务
文献注解
第十部分附录
附录a详细的大学模式
参考文献
索引
1.6.2大学机构的数据库设计
1.6.3实体-联系模型
1.6.4规范化
1.7数据存储和查询
1.7.1存储管理器
1.7.2查询处理器
1.8事务管理
1.9数据库体系结构
1.10数据挖掘与信息检索
1.11特种数据库
1.11.1基于对象的数据模型
1.11.2半结构化数据模型
1.12数据库用户和管理员
1.12.1数据库用户和用户界面
1.12.2数据库管理员
1.13数据库系统的历史
1.14总结
术语回顾
实践习题
习题
工具
文献注解
第一部分关系数据库
第2章关系模型介绍
2.1关系数据库的结构
2.2数据库模式
2.3码
2.4模式图
2.5关系查询语言
2.6关系运算
2.7总结
术语回顾
实践习题
习题
文献注解
第3章sql
3.1sql查询语言概览
3.2sql数据定义
3.2.1基本类型
3.2.2基本模式定义
3.3sql查询的基本结构
3.3.1单关系查询
3.3.2多关系查询
3.3.3自然连接
3.4附加的基本运算
3.4.1更名运算
3.4.2字符串运算
3.4.3select子句中的属性说明
3.4.4排列元组的显示次序
3.4.5where子句谓词
3.5集合运算
3.5.1并运算
3.5.2交运算
3.5.3差运算
3.6空值
3.7聚集函数
3.7.1基本聚集
3.7.2分组聚集
3.7.3having子句
3.7.4对空值和布尔值的聚集
3.8嵌套子查询
3.8.1集合成员资格
3.8.2集合的比较
3.8.3空关系测试
3.8.4重复元组存在性测试
3.8.5from子句中的子查询
3.8.6with子句
3.8.7标量子查询
3.9数据库的修改
3.9.1删除
3.9.2插入
3.9.3更新
3.10总结
术语回顾
实践习题
习题
工具
文献注解
第4章中级sql
4.1连接表达式
4.1.1连接条件
4.1.2外连接
4.1.3连接类型和条件
4.2视图
4.2.1视图定义
4.2.2sql查询中使用视图
4.2.3物化视图
4.2.4视图更新
4.3事务
4.4完整性约束
4.4.1单个关系上的约束
4.4.2not null约束
4.4.3unique约束
4.4.4check子句
4.4.5参照完整性
4.4.6事务中对完整性约束的违反
4.4.7复杂check条件与断言
4.5sql的数据类型与模式
4.5.1sql中的日期和时间类型
4.5.2默认值
4.5.3创建索引
4.5.4大对象类型
4.5.5用户定义的类型
4.5.6create table的扩展
4.5.7模式、目录与环境
4.6授权
4.6.1权限的授予与收回
4.6.2角色
4.6.3视图的授权
4.6.4模式的授权
4.6.5权限的转移
4.6.6权限的收回
4.7总结
术语回顾
实践习题
习题
文献注解
第5章高级sql
5.1使用程序设计语言访问数据库
5.1.1jdbc
5.1.2odbc
5.1.3嵌入式sql
5.2函数和过程
5.2.1声明和调用sql函数和过程
5.2.2支持过程和函数的语言构造
5.2.3外部语言过程
5.3触发器
5.3.1对触发器的需求
5.3.2sql中的触发器
5.3.3何时不用触发器
5.4递归查询**
5.4.1用迭代来计算传递闭包
5.4.2sql中的递归
5.5高级聚集特性**
5.5.1排名
5.5.2分窗
5.6olap**
5.6.1联机分析处理
5.6.2交叉表与关系表
5.6.3sql中的olap
5.7总结
术语回顾
实践习题
习题
工具
文献注解
第6章形式化关系查询语言
6.1关系代数
6.1.1基本运算
6.1.2关系代数的形式化定义
6.1.3附加的关系代数运算
6.1.4扩展的关系代数运算
6.2元组关系演算
6.2.1查询示例
6.2.2形式化定义
6.2.3表达式的安全性
6.2.4语言的表达能力
6.3域关系演算
6.3.1形式化定义
6.3.2查询的例子
6.3.3表达式的安全性
6.3.4语言的表达能力
6.4总结
术语回顾
实践习题
习题
文献注解
第二部分数据库设计
第7章数据库设计和er模型
7.1设计过程概览
7.1.1设计阶段
7.1.2设计选择
7.2实体-联系模型
7.2.1实体集
7.2.2联系集
7.2.3属性
7.3约束
7.3.1映射基数
7.3.2参与约束
7.3.3码
7.4从实体集中删除冗余属性
7.5实体-联系图
7.5.1基本结构
7.5.2映射基数
7.5.3复杂的属性
7.5.4角色
7.5.5非二元的联系集
7.5.6弱实体集
7.5.7大学的er图
7.6转换为关系模式
7.6.1具有简单属性的强实体集的表示
7.6.2具有复杂属性的强实体集的表示
7.6.3弱实体集的表示
7.6.4联系集的表示
7.7实体-联系设计问题
7.7.1用实体集还是用属性
7.7.2用实体集还是用联系集
7.7.3二元还是n元联系集
7.7.4联系属性的布局
7.8扩展的er特性
7.8.1特化
7.8.2概化
7.8.3属性继承
7.8.4概化上的约束
7.8.5聚集
7.8.6转换为关系模式
7.9数据建模的其他表示法
7.9.1er图的其他表示法
7.9.2统一建模语言uml
7.10数据库设计的其他方面
7.10.1数据约束和关系数据库设计
7.10.2使用需求:查询、性能
7.10.3授权需求
7.10.4数据流、工作流
7.10.5数据库设计的其他问题
7.11总结
术语回顾
实践习题
习题
工具
文献注解
第8章关系数据库设计
8.1好的关系设计的特点
8.1.1设计选择:更大的模式
8.1.2设计选择:更小的模式
8.2原子域和第一范式
8.3使用函数依赖进行分解
8.3.1码和函数依赖
8.3.2boycecodd范式
8.3.3bcnf和保持依赖
8.3.4第三范式
8.3.5更高的范式
8.4函数依赖理论
8.4.1函数依赖集的闭包
8.4.2属性集的闭包
8.4.3正则覆盖
8.4.4无损分解
8.4.5保持依赖
8.5分解算法
8.5.1bcnf分解
8.5.23nf分解
8.5.33nf算法的正确性
8.5.4bcnf和3nf的比较
8.6使用多值依赖的分解
8.6.1多值依赖
8.6.2第四范式
8.6.34nf分解
8.7更多的范式
8.8数据库设计过程
8.8.1er模型和规范化
8.8.2属性和联系的命名
8.8.3为了性能去规范化
8.8.4其他设计问题
8.9时态数据建模
8.10总结
术语回顾
实践习题
习题
文献注解
第9章应用设计和开发
9.1应用程序和用户界面
9.2web基础
9.2.1统一资源定位符
9.2.2超文本标记语言
9.2.3web服务器和会话
9.3servlet和jsp
9.3.1一个servlet的例子
9.3.2servlet会话
9.3.3servlet的生命周期
9.3.4servlet支持
9.3.5服务器端脚本
9.3.6客户端脚本
9.4应用架构
9.4.1业务逻辑层
9.4.2数据访问层和对象-关系映射
9.4.3web服务
9.4.4断连操作
9.5快速应用开发
9.5.1构建用户界面的工具
9.5.2web应用框架
9.5.3报表生成器
9.6应用程序性能
9.6.1利用缓存减少开销
9.6.2并行处理
9.7应用程序安全性
9.7.1sql注入
9.7.2跨站点脚本和请求伪造
9.7.3密码泄露
9.7.4应用程序认证
9.7.5应用级授权
9.7.6审计追踪
9.7.7隐私
9.8加密及其应用
9.8.1加密技术
9.8.2数据库中的加密支持
9.8.3加密和认证
9.9总结
术语回顾
实践习题
习题
项目建议
工具
文献注解
第三部分数据存储和查询
第10章存储和文件结构
10.1物理存储介质概述
10.2磁盘和快闪存储器
10.2.1磁盘的物理特性
10.2.2磁盘性能的度量
10.2.3磁盘块访问的优化
10.2.4快闪存储
10.3raid
10.3.1通过冗余提高可靠性
10.3.2通过并行提高性能
10.3.3raid级别
10.3.4raid级别的选择
10.3.5硬件问题
10.3.6其他的raid应用
10.4第三级存储
10.4.1光盘
10.4.2磁带
10.5文件组织
10.5.1定长记录
10.5.2变长记录
10.6文件中记录的组织
10.6.1顺序文件组织
10.6.2多表聚簇文件组织
10.7数据字典存储
10.8数据库缓冲区
10.8.1缓冲区管理器
10.8.2缓冲区替换策略
10.9总结
术语回顾
实践习题
习题
文献注解
第11章索引与散列
11.1基本概念
11.2顺序索引
11.2.1稠密索引和稀疏索引
11.2.2多级索引
11.2.3索引的更新
11.2.4辅助索引
11.2.5多码上的索引
11.3b+树索引文件
11.3.1b+树的结构
11.3.2b+树的查询
11.3.3b+树的更新
11.3.4不唯一的搜索码
11.3.5b+树更新的复杂性
11.4b+树扩展
11.4.1b+树文件组织
11.4.2辅助索引和记录重定位
11.4.3字符串上的索引
11.4.4b+树索引的批量加载
11.4.5b树索引文件
11.4.6闪存
11.5多码访问
11.5.1使用多个单码索引
11.5.2多码索引
11.5.3覆盖索引
11.6静态散列
11.6.1散列函数
11.6.2桶溢出处理
11.6.3散列索引
11.7动态散列
11.7.1数据结构
11.7.2查询和更新
11.7.3静态散列与动态散列比较
11.8顺序索引和散列的比较
11.9位图索引
11.9.1位图索引结构
11.9.2位图操作的高效实现
11.9.3位图和b+树
11.10sql中的索引定义
11.11总结
术语回顾
实践习题
习题
文献注解
第12章查询处理
12.1概述
12.2查询代价的度量
12.3选择运算
12.3.1使用文件扫描和索引的选择
12.3.2涉及比较的选择
12.3.3复杂选择的实现
12.4排序
12.4.1外部排序归并算法
12.4.2外部排序归并的代价分析
12.5连接运算
12.5.1嵌套循环连接
12.5.2块嵌套循环连接
12.5.3索引嵌套循环连接
12.5.4归并连接
12.5.5散列连接
12.6其他运算
12.6.1去除重复
12.6.2投影
12.6.3集合运算
12.6.4外连接
12.6.5聚集
12.7表达式计算
12.7.1物化
12.7.2流水线
12.8总结
术语回顾
实践习题
习题
文献注解
第13章查询优化
13.1概述
13.2关系表达式的转换
13.2.1等价规则
13.2.2转换的例子
13.2.3连接的次序
13.2.4等价表达式的枚举
13.3表达式结果集统计大小的估计
13.3.1目录信息
13.3.2选择运算结果大小的估计
13.3.3连接运算结果大小的估计
13.3.4其他运算的结果集大小的估计
13.3.5不同取值个数的估计
13.4执行计划选择
13.4.1基于代价的连接顺序选择
13.4.2采用等价规则的基于代价的优化器
13.4.3启发式优化
13.4.4嵌套子查询的优化**
13.5物化视图**
13.5.1视图维护
13.5.2增量的视图维护
13.5.3查询优化和物化视图
13.5.4物化视图和索引选择
13.6查询优化中的高级话题**
13.6.1topk优化
13.6.2连接极小化
13.6.3更新的优化
13.6.4多查询优化和共享式扫描
13.6.5参数化查询优化
13.7总结
术语回顾
实践习题
习题
文献注解
第四部分事务管理
第14章事务
14.1事务概念
14.2一个简单的事务模型
14.3存储结构
14.4事务原子性和持久性
14.5事务隔离性
14.6可串行化
14.7事务隔离性和原子性
14.7.1可恢复调度
14.7.2无级联调度
14.8事务隔离性级别
14.9隔离性级别的实现
14.9.1锁
14.9.2时间戳
14.9.3多版本和快照隔离
14.10事务的sql语句表示
14.11总结
术语回顾
实践习题
习题
文献注解
第15章并发控制
15.1基于锁的协议
15.1.1锁
15.1.2锁的授予
15.1.3两阶段封锁协议
15.1.4封锁的实现
15.1.5基于图的协议
15.2死锁处理
15.2.1死锁预防
15.2.2死锁检测与恢复
15.3多粒度
15.4基于时间戳的协议
15.4.1时间戳
15.4.2时间戳排序协议
15.4.3thomas写规则
15.5基于有效性检查的协议
15.6多版本机制
15.6.1多版本时间戳排序
15.6.2多版本两阶段封锁
15.7快照隔离
15.7.1更新事务的有效性检验步骤
15.7.2串行化问题
15.8插入操作、删除操作与谓词读
15.8.1删除
15.8.2插入
15.8.3谓词读和幻象现象
15.9实践中的弱一致性级别
15.9.1二级一致性
15.9.2游标稳定性
15.9.3跨越用户交互的并发控制
15.10索引结构中的并发**
15.11总结
术语回顾
实践习题
习题
文献注解
第16章恢复系统
16.1故障分类
16.2存储器
16.2.1稳定存储器的实现
16.2.2数据访问
16.3恢复与原子性
16.3.1日志记录
16.3.2数据库修改
16.3.3并发控制和恢复
16.3.4事务提交
16.3.5使用日志来重做和撤销事务
16.3.6检查点
16.4恢复算法
16.4.1事务回滚
16.4.2系统崩溃后的恢复
16.5缓冲区管理
16.5.1日志记录缓冲
16.5.2数据库缓冲
16.5.3操作系统在缓冲区管理中的作用
16.5.4模糊检查点
16.6非易失性存储器数据丢失的故障
16.7锁的提前释放和逻辑undo操作
16.7.1逻辑操作
16.7.2逻辑undo日志记录
16.7.3有逻辑undo的事务回滚
16.7.4逻辑undo中的并发问题
16.8aries**
16.8.1数据结构
16.8.2恢复算法
16.8.3其他特性
16.9远程备份系统
16.10总结
术语回顾
实践习题
习题
文献注解
第五部分系统体系结构
第17章数据库系统体系结构
17.1集中式与客户-服务器体系结构
17.1.1集中式系统
17.1.2客户-服务器系统
17.2服务器系统体系结构
17.2.1事务服务器
17.2.2数据服务器
17.2.3基于云的服务器
17.3并行系统
17.3.1加速比和扩展比
17.3.2互连网络
17.3.3并行数据库体系结构
17.4分布式系统
17.4.1分布式数据库示例
17.4.2实现问题
17.5网络类型
17.5.1局域网
17.5.2广域网
17.6总结
术语回顾
实践习题
习题
文献注解
第18章并行数据库
18.1引言
18.2i/o并行
18.2.1划分技术
18.2.2划分技术比较
18.2.3偏斜处理
18.3查询间并行
18.4查询内并行
18.5操作内并行
18.5.1并行排序
18.5.2并行连接
18.5.3其他关系运算
18.5.4运算的并行计算代价
18.6操作间并行
18.6.1流水线并行
18.6.2独立并行
18.7查询优化
18.8并行系统设计
18.9多核处理器的并行性
18.9.1并行性与原始速度
18.9.2高速缓冲存储器和多线程
18.9.3适应现代体系架构的数据库系统设计
18.10总结
术语回顾
实践习题
习题
文献注解
第19章分布式数据库
19.1同构和异构数据库
19.2分布式数据存储
19.2.1数据复制
19.2.2数据分片
19.2.3透明性
19.3分布式事务
19.3.1系统结构
19.3.2系统故障模式
19.4提交协议
19.4.1两阶段提交
19.4.2三阶段提交
19.4.3事务处理的可选择性模型
19.5分布式数据库中的并发控制
19.5.1封锁协议
19.5.2时间戳
19.5.3弱一致性级别的复制
19.5.4死锁处理
19.6可用性
19.6.1基于多数的方法
19.6.2读一个、写所有可用的方法
19.6.3站点重建
19.6.4与远程备份的比较
19.6.5协调器的选择
19.6.6为可用性而牺牲一致性
19.7分布式查询处理
19.7.1查询转换
19.7.2简单的连接处理
19.7.3半连接策略
19.7.4利用并行性的连接策略
19.8异构分布式数据库
19.8.1数据统一视图
19.8.2查询处理
19.8.3多数据库中的事务管理
19.9基于云的数据库
19.9.1云上的数据存储系统
19.9.2云上的传统数据库
19.9.3基于云的数据库的挑战
19.10目录系统
19.10.1目录访问协议
19.10.2ldap:轻量级目录访问协议
19.11总结
术语回顾
实践习题
习题
文献注解
第六部分数据仓库、数据挖掘与信息检索
第20章数据仓库与数据挖掘
20.1决策支持系统
20.2数据仓库
20.2.1数据仓库成分
20.2.2数据仓库模式
20.2.3面向列的存储
20.3数据挖掘
20.4分类
20.4.1决策树分类器
20.4.2其他类型的分类器
20.4.3回归
20.4.4分类器验证
20.5关联规则
20.6其他类型的关联
20.7聚类
20.8其他类型的数据挖掘
20.9总结
术语回顾
实践习题
习题
工具
文献注解
第21章信息检索
21.1概述
21.2使用术语的相关性排名
21.2.1使用tfidf的排名方法
21.2.2基于相似性的检索
21.3使用超链接的相关性
21.3.1流行度排名
21.3.2pagerank
21.3.3其他的流行度度量
21.3.4搜索引擎
21.3.5将tfidf和流行度排名度量方法结合
21.4同义词、多义词和本体
21.5文档的索引
21.6检索的有效性度量
21.7web的抓取和索引
21.8信息检索:网页排名之外
21.8.1查询结果的多样化
21.8.2信息抽取
21.8.3问答系统
21.8.4查询结构化数据
21.9目录与分类
21.10总结
术语回顾
实践习题
习题
工具
文献注解
第七部分特种数据库
第22章基于对象的数据库
22.1概述
22.2复杂数据类型
22.3sql中的结构类型和继承
22.3.1结构类型
22.3.2类型继承
22.4表继承
22.5sql中的数组和多重集合类型
22.5.1创建和访问集合体值
2.5.2查询以集合体为值的属性
22.5.3嵌套和解除嵌套
22.6sql中的对象标识和引用类型
22.7or特性的实现
22.8持久化程序设计语言
22.8.1对象的持久化
22.8.2对象标识和指针
22.8.3持久对象的存储和访问
22.8.4持久化c++系统
22.8.5持久化java系统
22.9对象-关系映射
22.10面向对象与对象-关系
22.11总结
术语回顾
实践习题
习题
工具
文献注解
第23章xml
23.1动机
23.2xml数据结构
23.3xml文档模式
23.3.1文档类型定义
23.3.2xml schema
23.4查询和转换
23.4.1xml树模型
23.4.2xpath
23.4.3xquery
23.5xml应用程序接口
23.6xml数据存储
23.6.1非关系的数据存储
23.6.2关系数据库
23.6.3sql/xml
23.7xml应用
23.7.1存储复杂结构数据
23.7.2标准化数据交换格式
23.7.3web服务
23.7.4数据中介
23.8总结
术语回顾
实践习题
习题
工具
文献注解
第八部分高级主题
第24章高级应用开发
24.1性能调整
24.1.1提高面向集合的特性
24.1.2批量加载和更新的调整
24.1.3瓶颈位置
24.1.4可调参数
24.1.5硬件调整
24.1.6模式调整
24.1.7索引调整
24.1.8使用物化视图
24.1.9物理设计的自动调整
24.1.10并发事务调整
24.1.11性能模拟
24.2性能基准程序
24.2.1任务集
24.2.2数据库应用类型
24.2.3tpc基准程序
24.3应用系统开发的其他问题
24.3.1应用系统测试
24.3.2应用系统移植
24.4标准化
24.4.1sql标准
24.4.2数据库连接标准
24.4.3对象数据库标准
24.4.4基于xml的标准
24.5总结
术语回顾
实践习题
习题
文献注解
第25章时空数据和移动性
25.1动机
25.2数据库中的时间
25.2.1sql中的时间规范
25.2.2时态查询语言
25.3空间与地理数据
25.3.1几何信息表示
25.3.2设计数据库
25.3.3地理数据
25.3.4空间查询
25.3.5空间数据的索引
25.4多媒体数据库
25.4.1多媒体数据格式
25.4.2连续媒体数据
25.4.3基于相似性的检索
25.5移动性和个人数据库
25.5.1移动计算模型
25.5.2路由和查询处理
25.5.3广播数据
25.5.4连接断开与一致性
25.6总结
术语回顾
实践习题
习题
文献注解
26章高级事务处理
26.1事务处理监控器
26.1.1tp监控器体系结构
26.1.2使用tp监控器进行应用协调
26.2事务工作流
26.2.1工作流说明
26.2.2工作流的故障原子性需求
26.2.3工作流执行
26.2.4工作流恢复
26.2.5工作流管理系统
26.3电子商务
26.3.1电子目录
26.3.2市场
26.3.3订单结算
26.4主存数据库
26.5实时事务系统
26.6长事务
26.6.1不可串行化的执行
26.6.2并发控制
26.6.3嵌套事务和多级事务
26.6.4补偿事务
26.6.5实现问题
26.7总结
术语回顾
实践习题
习题
文献注解
第九部分实例研究
第27章postgresql
27.1概述
27.2用户界面
27.2.1交互式终端界面
27.2.2图形界面
27.2.3编程语言接口
27.3sql变化和扩展
27.3.1postgresql类型
27.3.2规则和其他主动数据库特征
27.3.3可扩展性
27.4postgresql中的事务管理
27.4.1postgresql的并发控制
27.4.2恢复
27.5存储和索引
27.5.1表
27.5.2索引
27.6查询处理和优化
27.6.1查询重写
27.6.2查询规划和优化
27.6.3查询执行器
27.6.4触发器和约束
27.7系统结构
文献注解
第28章oracle
28.1数据库设计和查询工具
28.1.1数据库和应用设计工具
28.1.2查询工具
28.2sql的变化和扩展
28.2.1对象-关系特性
28.2.2oracle xml db
28.2.3过程化语言
28.2.4维度
28.2.5联机分析处理
28.2.6触发器
28.3存储和索引
28.3.1表空间
28.3.2段
28.3.3表
28.3.4索引
28.3.5位图索引
28.3.6基于函数的索引
28.3.7连接索引
28.3.8域索引
28.3.9划分
28.3.10物化视图
28.4查询处理和优化
28.4.1执行方法
28.4.2优化
28.4.3并行执行
28.4.4结果高速缓存
28.5并发控制与恢复
28.5.1并发控制
28.5.2恢复的基本结构
28.5.3oracle数据卫士
28.6系统体系结构
28.6.1专用服务器:内存结构
28.6.2专用服务器:进程结构
28.6.3共享服务器
28.6.4oracle real application clusters
28.6.5自动存储管理器
28.6.6oracle exadata
28.7复制、分布以及外部数据
28.7.1复制
28.7.2分布式数据库
28.7.3外部数据源
28.8数据库管理工具
28.8.1oracle企业管理器
28.8.2自动工作负载存储
28.8.3数据库资源管理
28.9数据挖掘
文献注解
第29章ibm db2 universal database
29.1概述
29.2数据库设计工具
29.3sql的变化和扩展
29.3.1xml特性
29.3.2数据类型的支持
29.3.3用户自定义函数和方法
29.3.4大对象
29.3.5索引扩展和约束
29.3.6web服务
29.3.7其他特性
29.4存储和索引
29.4.1存储体系结构
29.4.2缓冲池
29.4.3表、记录和索引
29.5多维聚簇
29.5.1块索引
29.5.2块映射
29.5.3设计考虑
29.5.4对现有技术的影响
29.6查询处理和优化
29.6.1存取方法
29.6.2连接、聚集和集合运算
29.6.3对复杂sql处理的支持
29.6.4多处理器查询处理特性
29.6.5查询优化
29.7物化的查询表
29.7.1查询路由到mqt
29.7.2mqt的维护
29.8db2中的自治特性
29.8.1配置
29.8.2优化
29.9工具和实用程序
29.10并发控制和恢复
29.10.1并发与隔离
29.10.2提交与回滚
29.10.3日志与恢复
29.11系统体系结构
29.12复制、分布和外部数据
29.13商务智能特性
文献注解
30章microsoft sql server
30.1管理、设计和查询工具
30.1.1数据库开发和可视化数据库工具
30.1.2数据库查询和调优工具
30.1.3sql server management studio
30.2sql变化和扩展
30.2.1数据类型
30.2.2查询语言增强
30.2.3例程
30.2.4带过滤的索引
30.3存储和索引
30.3.1文件组
30.3.2文件组内的空间管理
30.3.3表
30.3.4索引
30.3.5分区
30.3.6在线创建索引
30.3.7扫描和预读
30.3.8压缩
30.4查询处理和优化
30.4.1编译处理概述
30.4.2查询简化
30.4.3重排序和基于代价的优化
30.4.4更新计划
30.4.5优化时的数据分析
30.4.6部分搜索和启发式搜索
30.4.7查询执行
30.5并发与恢复
30.5.1事务
30.5.2封锁
30.5.3恢复和可用性
30.6系统体系结构
30.6.1服务器上的线程池
30.6.2内存管理
30.6.3安全性
30.7数据访问
30.8分布式异构查询处理
30.9复制
30.9.1复制模型
30.9.2复制选项
30.10.net中的服务器编程
30.10.1.net基本概念
30.10.2sql clr宿主
30.10.3可扩展性协定
30.11xml支持
30.11.1本地存储和组织xml
30.11.2查询和更新xml数据类型
30.11.3xquery表达式的执行
30.12sql server服务代理
30.13商务智能
30.13.1sql server集成服务
30.13.2sql server分析服务
30.13.3sql server报表服务
文献注解
第十部分附录
附录a详细的大学模式
参考文献
索引
前言
数据库管理已经从一种专门的计算机应用发展为现代计算环境中的一个重要成分,因此,有关数据库系统的知识已成为计算机科学教育中的一个核心的部分。在本书中,我们讲述数据库管理的基本概念。这些概念包括数据库设计、数据库语言、数据库系统实现等多个方面。
本书可作为本科生三年级或四年级数据库入门课程的教科书,也可作为研究生一年级的教科书。除了作为入门课程的基本内容外,本书还包括了可作为课程补充或作为高级课程介绍性材料的高级内容。
我们仅要求读者熟悉基本的数据结构、计算机组织结构和一种高级程序设计语言,例如Java、C或Pascal。书中的概念都以直观的方式加以描述,其中的许多概念都基于我们大学运行的例子加以阐释。本书中包括重要的理论结果,但省略了形式化证明,取而代之的是用图表和例子来说明为什么结论是正确的。对于形式化描述和研究结果的证明,读者可以参考文献注解中列出的研究论文和高级教材。
计算机书籍中所包括的基本概念和算法通常是基于当今的商品化或试验性的数据库系统中采用的概念和算法。我们的目标是在一个通常环境下描述这些概念和算法,而没有与某个特定的数据库系统绑定。特定的数据库系统的细节将在第九部分“实例研究”中讨论。
在本书第6版中,我们保持了前面版本的总体风格,同时对内容和结构进行了扩展来反映数据库设计、管理和使用的方式所发生的变化。我们还考虑了数据库概念的教学方面的趋势,并在适当的地方做出了推动这种趋势的修改。
本书的组织
本书组织成十个主要部分:
综述(第1章)。第1章对数据库系统的性质和目标进行了一般性综述。计算机书籍我们解释了数据库系统的概念是如何发展的,各数据库系统的共同特性是什么,数据库系统能为用户做什么,以及数据库系统如何与操作系统交互。我们还引入了一个数据库应用的例子:包括多个系、教员、学生和课程的一个大学机构。这个应用作为贯穿全书的运行实例。这一章本质上是诱导性、历史性和解释性的。
第一部分:关系数据库(第2章至第6章)。第2章介绍了数据的关系模型,包括基本概念,诸如关系数据库的结构、数据库模式、码、模式图、关系查询语言和关系操作等。计算机书籍第3~5章主要介绍最具影响力的面向用户的关系语言——SQL。第6章介绍形式化的关系查询语言,包括关系代数、元组关系演算和域关系演算。
这部分描述了数据操纵,包括查询、修改、插入和删除(假设已有一个模式设计)。关于模式设计的问题延迟到第二部分讲述。
第二部分:数据库设计(第7章至第9章)。第7章给出了数据库设计过程的概要介绍,主要侧重于用实体-联系数据模型来进行数据库设计。实体-联系模型为数据库设计问题,以及我们在数据模型的约束下捕获现实应用的语义时所遇到的问题提供了一个高层视图。UML类图表示也在这一章中讲述。
第8章介绍关系数据库设计理论。这一章讲述函数依赖和规范化,重点强调提出各种范式的动机,以及它们的直观含义。这一章以关系设计的概览开始,依赖于对函数依赖的逻辑蕴涵的直观理解。这使得规范化的概念可以在函数依赖理论的完整内容之前先作介绍。函数依赖理论将在本章中稍后部分讨论。教师可以只选用8.1节至8.3节这些较前面的章节,而不会丢失连贯性。不过,完整地讲授这一章将有利于学生对规范化概念形成较好的理解,从而诱导出函数依赖理论中一些较艰深的概念。
第9章讲述应用设计和开发。这一章侧重于用基于Web的界面构建数据库应用。另外,这一章还讲述了应用安全性。
第三部分:数据存储和查询(第10章至第13章)。第10章讨论存储设备、文件和数据存储结构。在第11章中介绍多种数据存取技术,包括B+树索引和散列。第12章和第13章阐述查询执行算法和查询优化。这两章使用户能更好地理解数据库的存储和检索的内部机制。
第四部分:事务管理(第14章至第16章)。第14章着重介绍事务处理系统的基本概念,包括原子性、一致性、隔离性和持久性。它还提供了用于保证这些特性的方法的一个概述,包括封锁和快照隔离性。
第15章重点讲述并发控制,并介绍保证可串行化的几种技术,包括封锁、时间戳和乐观(有效性检查)技术。在这一章中还讨论死锁问题,并介绍保证可串行化的其他方法,特别是详细讨论广泛使用的快照隔离方法。
第16章讨论在系统崩溃和存储器故障情况下保证事务正确执行的主要技术。这些技术包括日志、检查点和数据库转储。被广泛使用的ARIES算法也在这里做了介绍。
第五部分:系统体系结构(第17章至第19章)。第17章介绍计算机系统体系结构,并描述了作为基础的计算机系统对于数据库系统的影响。在这一章中讨论了集中式系统、客户-服务器系统、并行和分布式体系结构。
在第18章关于并行数据库的讨论中,我们探讨了各种并行技术,包括I/O并行、查询间并行和查询内并行,以及操作间并行和操作内并行。这一章中还讨论了并行系统设计。
第19章讨论分布式数据库系统,在分布式数据库系统的环境下重新讨论数据库设计、事务管理、查询执行和优化问题。这一章还包括了故障时的系统可用性问题,并介绍了异构分布式数据库、基于云的数据库和分布式目录系统。
本书可作为本科生三年级或四年级数据库入门课程的教科书,也可作为研究生一年级的教科书。除了作为入门课程的基本内容外,本书还包括了可作为课程补充或作为高级课程介绍性材料的高级内容。
我们仅要求读者熟悉基本的数据结构、计算机组织结构和一种高级程序设计语言,例如Java、C或Pascal。书中的概念都以直观的方式加以描述,其中的许多概念都基于我们大学运行的例子加以阐释。本书中包括重要的理论结果,但省略了形式化证明,取而代之的是用图表和例子来说明为什么结论是正确的。对于形式化描述和研究结果的证明,读者可以参考文献注解中列出的研究论文和高级教材。
计算机书籍中所包括的基本概念和算法通常是基于当今的商品化或试验性的数据库系统中采用的概念和算法。我们的目标是在一个通常环境下描述这些概念和算法,而没有与某个特定的数据库系统绑定。特定的数据库系统的细节将在第九部分“实例研究”中讨论。
在本书第6版中,我们保持了前面版本的总体风格,同时对内容和结构进行了扩展来反映数据库设计、管理和使用的方式所发生的变化。我们还考虑了数据库概念的教学方面的趋势,并在适当的地方做出了推动这种趋势的修改。
本书的组织
本书组织成十个主要部分:
综述(第1章)。第1章对数据库系统的性质和目标进行了一般性综述。计算机书籍我们解释了数据库系统的概念是如何发展的,各数据库系统的共同特性是什么,数据库系统能为用户做什么,以及数据库系统如何与操作系统交互。我们还引入了一个数据库应用的例子:包括多个系、教员、学生和课程的一个大学机构。这个应用作为贯穿全书的运行实例。这一章本质上是诱导性、历史性和解释性的。
第一部分:关系数据库(第2章至第6章)。第2章介绍了数据的关系模型,包括基本概念,诸如关系数据库的结构、数据库模式、码、模式图、关系查询语言和关系操作等。计算机书籍第3~5章主要介绍最具影响力的面向用户的关系语言——SQL。第6章介绍形式化的关系查询语言,包括关系代数、元组关系演算和域关系演算。
这部分描述了数据操纵,包括查询、修改、插入和删除(假设已有一个模式设计)。关于模式设计的问题延迟到第二部分讲述。
第二部分:数据库设计(第7章至第9章)。第7章给出了数据库设计过程的概要介绍,主要侧重于用实体-联系数据模型来进行数据库设计。实体-联系模型为数据库设计问题,以及我们在数据模型的约束下捕获现实应用的语义时所遇到的问题提供了一个高层视图。UML类图表示也在这一章中讲述。
第8章介绍关系数据库设计理论。这一章讲述函数依赖和规范化,重点强调提出各种范式的动机,以及它们的直观含义。这一章以关系设计的概览开始,依赖于对函数依赖的逻辑蕴涵的直观理解。这使得规范化的概念可以在函数依赖理论的完整内容之前先作介绍。函数依赖理论将在本章中稍后部分讨论。教师可以只选用8.1节至8.3节这些较前面的章节,而不会丢失连贯性。不过,完整地讲授这一章将有利于学生对规范化概念形成较好的理解,从而诱导出函数依赖理论中一些较艰深的概念。
第9章讲述应用设计和开发。这一章侧重于用基于Web的界面构建数据库应用。另外,这一章还讲述了应用安全性。
第三部分:数据存储和查询(第10章至第13章)。第10章讨论存储设备、文件和数据存储结构。在第11章中介绍多种数据存取技术,包括B+树索引和散列。第12章和第13章阐述查询执行算法和查询优化。这两章使用户能更好地理解数据库的存储和检索的内部机制。
第四部分:事务管理(第14章至第16章)。第14章着重介绍事务处理系统的基本概念,包括原子性、一致性、隔离性和持久性。它还提供了用于保证这些特性的方法的一个概述,包括封锁和快照隔离性。
第15章重点讲述并发控制,并介绍保证可串行化的几种技术,包括封锁、时间戳和乐观(有效性检查)技术。在这一章中还讨论死锁问题,并介绍保证可串行化的其他方法,特别是详细讨论广泛使用的快照隔离方法。
第16章讨论在系统崩溃和存储器故障情况下保证事务正确执行的主要技术。这些技术包括日志、检查点和数据库转储。被广泛使用的ARIES算法也在这里做了介绍。
第五部分:系统体系结构(第17章至第19章)。第17章介绍计算机系统体系结构,并描述了作为基础的计算机系统对于数据库系统的影响。在这一章中讨论了集中式系统、客户-服务器系统、并行和分布式体系结构。
在第18章关于并行数据库的讨论中,我们探讨了各种并行技术,包括I/O并行、查询间并行和查询内并行,以及操作间并行和操作内并行。这一章中还讨论了并行系统设计。
第19章讨论分布式数据库系统,在分布式数据库系统的环境下重新讨论数据库设计、事务管理、查询执行和优化问题。这一章还包括了故障时的系统可用性问题,并介绍了异构分布式数据库、基于云的数据库和分布式目录系统。
. 第六部分:数据仓库、数据挖掘与信息检索(第20章和第21章)。第20章介绍数据仓库和数据挖掘的概念。第21章描述用于查询文本数据的信息检索技术,包括在Web搜索引擎中使用的基于超链接的技术。
第六部分使用了第一部分和第二部分的模型和语言概念,但并不依赖于第三部分、第四部分或第五部分。因此它可以很容易地结合到侧重于SQL和数据库设计的课程中。
第七部分:特种数据库(第22章和第23章)。第22章介绍基于对象的数据库。该章讲述了对象-关系数据模型,该模型扩展了关系数据模型以支持复杂数据类型、类型继承和对象标识。该章还描述了用面向对象的编程语言来访问数据库。
第23章介绍数据表示的XML标准,它正日益广泛地应用于复杂数据交换和存储。这一章还描述了XML的查询语言。
第八部分:高级主题(第24章至第26章)。第24章讨论应用开发中的高级话题,包括性能调整、性能评测标准、数据库应用测试和标准化。
第25章介绍空间和地理数据、时间数据、多媒体数据以及移动和个人数据库管理中的问题。
最后,第26章讨论高级事务处理。这一章的内容包括事务处理监控器、事务工作流、电子商务、高性能事务系统、实时事务系统和持续长时间的事务。
第九部分:实例研究(第27章至第30章)。在这一部分我们对四个领先的数据库系统进行实例研究,包括PostgreSQL、Oracle、IBM DB2和Microsoft SQL Server。这几章中列举了上述每一种系统的独有特性,描述了它们的内部结构,提供了关于各个产品的丰富的有用信息,帮助读者了解前面各部分描述的各种实现技术是如何使用到实际系统中的。这几章中还包括实际系统设计中的几个有趣的方面。
第6版
对于本书第6版的产生起指导作用的包括我们收到的关于前面几版的许多意见和建议,我们在耶鲁大学、利哈依大学、孟买印度理工学院讲授本课程的体会,以及我们对于数据库技术发展方向的分析。
我们用一个大学的例子替换了原先的银行企业的运行例子。这个例子与学生相关,不仅有助于他们记住这个例子,而且更重要的是,使他们能够更深地洞察所需进行的各种设计决策。
我们重新组织了这本书,将我们关于SQL的介绍都集中在一起,放在本书的开头部分。第3章、第4章和第5章对SQL进行完整的介绍。第3章给出该语言的基础,而将更高级的特性放在了第4章。在第5章中,我们介绍从通用的程序设计语言访问SQL的JDBC和其他方法。我们介绍触发器和递归,最后讨论联机分析处理(OLAP)。入门性的课程可以选择只包括第5章的某些节,或者将一些节延迟到讲过了数据库设计之后再讲,这样也不失连续性。
除了这两个主要的改变外,我们修订了每一章中的素材,对旧的素材进行更新,增加对于数据库技术的新的发展的讨论,并且改进学生难于理解的那些内容的描述。我们还增加了新的练习并更新了参考文献。具体的改变如下。
较早介绍了SQL。许多讲课教师使用SQL作为课程实习的核心成分。为了给学生充足的时间做课程实习,尤其对于那些四学期制的大学和学院来说,尽早教授SQL非常重要。有了这个认识,我们在内容组织方面做了几个改动:
□ 用新的一章(第2章)介绍关系模型,放在SQL之前,打下概念基础,而不使学生迷失在关系代数的细节中。
□ 第3章、第4章和第5章详细介绍SQL。这几章还讨论不同的数据库系统支持的变体,从而当学生在实际的数据库系统上执行查询时会少遇到一些问题。这几章涵盖了SQL的所有方面,包括查询、数据定义、约束说明、OLAP和从各种语言(包括Java/JDBC)内部使用SQL。
□ 形式语言(第6章)推迟到SQL之后,而且可以略掉不讲,而不会影响其他章的顺序。只有在第13章关于查询优化的讨论依赖于第6章介绍的关系代数。
新的数据库模式。我们采用了一个新的模式作为贯穿全书的运行实例,基于大学的数据。对于学生来说,这个模式比以前的银行模式更加直观和有意义,而且在数据库设计的章节中展示了更复杂的设计权衡。
对学生的亲手实践提供了更多的支持。为了推动学生跟着我们的运行实例进行实践,我们在附录A中列出了大学数据库的数据库模式和样例的关系实例,并在用到大学实例的各个章中也进行了说明。另外,在我们的Web站点http://www.dbbook.com上,提供了对于整个例子的SQL数据定义语句,以及建立我们的样例关系实例的SQL语句。这鼓励了学生直接在一个实际的数据库系统中去运行样例查询,并且试着去修改这些查询。
修订了对ER模型的涵盖。我们修改了第7章中ER图的符号表示,以使得它与UML更兼容。这一章还充分利用了新的大学数据库模式来描述更复杂的设计权衡。
修订了对关系设计的涵盖。第8章的风格现在更具可读性,它在阐述函数依赖理论之前提供了对函数依赖和规范化的一个直观的理解,其结果是理论的动机更清晰了。
扩充了关于应用开发和安全性的素材。第9章包括了关于应用开发的新的素材,以反映该领域的快速变化。特别地,扩展了关于安全性的介绍,包括它在当今紧密互联的世界中的至关重要性,并重点强调了抽象概念外的实际问题。
修订和更新了对数据存储、索引和查询优化的涵盖。对第10章进行了新技术方面的更新,包括对闪存的更多的讨论。
更新了第11章对B+树的讨论,以反映实际的实现,包括对批量载入的介绍,并且对陈述方式也进行了改进。第11章中B+树的例子修改成了n=4,以避免(不切实际的)n=3时发生的空结点的特殊情况。
第13章中有关于高级查询优化技术的新的素材。
修订了对事务管理的涵盖。第14章全面涵盖了入门性课程中的基础知识,而高级的细节在第15章和第16章中介绍。我们扩展了第14章,以涵盖数据库用户和数据库应用开发人员所面对的事务管理的实际问题。这一章还包括了对第15章和第16章所讨论话题的扩展的综述,以确保即使略掉第15章和第16章,学生仍能对并发控制和恢复的概念有基本的了解。
第14章和第15章现在包括了对当今被广泛支持和使用的快照隔立性的详细介绍,对于使用它的潜在风险也做了介绍。
第16章现在对基本的基于日志的恢复进行了简化的描述,进一步介绍了ARIES算法。
修订和扩充了对分布式数据库的涵盖。我们现在涵盖了云数据存储,它在商业应用中正日益受到极大的重视。云存储为企业提供了改进成本管理和增加存储可扩充性的机遇,特别是对于基于Web的应用。我们分析了这些优点,也指出了可能的缺点和风险。
我们原来在高级事务处理这一章中讨论多数据库,现在对它更早地进行了介绍,作为分布式数据库这一章中的一部分。
推迟了对对象数据库和XML的介绍。虽然面向对象的语言和XML在数据库的范围之外被广泛使用,但在数据库中的使用仍然有限,这使得它们对于高级课程或作为入门性课程的补充材料更适合一些。因此这些话题在本书中向后移了,放到了第22章和第23章。
QBE、Microsoft Access和Datalog放在联机附录中。这些话题原来是“其他关系语言”这一章中的一部分,现在放在联机附录C中了。
上面没有列出的所有话题都在第5版的基础上做了更新,虽然相对地它们的总体组织没有改变。
回顾材料和习题
每一章都有一个术语回顾表,还有一个总结,这可以帮助读者回顾这一章中涵盖的关键话题。
练习划分成两部分:实践习题(practice exercise)和习题(exercise)。实践习题的解答在本书的Web站点公开发布。我们鼓励学生独立解决这些实践习题,然后用Web站点上的解答来检查自己的答案。其他练习题的解答只有讲课教师能得到(参看下面的“讲课教师注意事项”以获取如何得到题解的信息)。
许多章的末尾有一个“工具”节,它提供与该章的话题相关的软件工具的信息;这些工具中的一些可以用于实验室练习。大学数据库和习题中用到的其他关系的SQL DDL和样例数据在本书的Web站点可以得到,也可以用于实验室练习。
讲课教师注意事项
本书包括基本内容和高级内容,在一个学期内也许不能讲授所有这些内容。我们以符号“**”把某些节标记为高级内容,如果愿意的话可以省略这些节,而仍能保持内容的连续性。较难的(可以忽略的)练习同样用符号“**”标记出来了。
可以用本书各章的不同子集来设计课程。某些章也可以用不同于本书中的顺序来讲授。我们列出一些可能的安排如下:
第5章可以跳过或推迟到后面讲,而不失连续性。我们期望大多数的课程至少5.1.1节较早地讲授,因为JDBC很可能会是学生实习的一个有用工具。
第6章可以在第2章之后、讲SQL之前讲。也可以把这一章从入门性的课程中省略掉。
我们建议如果课程中讲查询处理的话,那么把6.1节也包括在课程中。但是,如果学生在课程中不使用关系演算的话,那么6.2节和6.3节可以省略。
如果教师愿意的话,第7章可以在第3章、第4章和第5章之前讲,因为第7章完全不依赖于SQL。
第13章可以从入门性的课程中省略掉,而对于其他任何章的讲授都没有影响。
我们对事务处理的讨论(第14章至第16章)和对系统体系结构的讨论(第17章至第19章)都包括一章综述(分别为第14章和第17章)和后续的两章详细讨论。如果计划把后面几章推迟到高级课程中去讲授,可以选择使用第14章和第17章,省略第15章、第16章、第18章和第19章。
第六部分使用了第一部分和第二部分的模型和语言概念,但并不依赖于第三部分、第四部分或第五部分。因此它可以很容易地结合到侧重于SQL和数据库设计的课程中。
第七部分:特种数据库(第22章和第23章)。第22章介绍基于对象的数据库。该章讲述了对象-关系数据模型,该模型扩展了关系数据模型以支持复杂数据类型、类型继承和对象标识。该章还描述了用面向对象的编程语言来访问数据库。
第23章介绍数据表示的XML标准,它正日益广泛地应用于复杂数据交换和存储。这一章还描述了XML的查询语言。
第八部分:高级主题(第24章至第26章)。第24章讨论应用开发中的高级话题,包括性能调整、性能评测标准、数据库应用测试和标准化。
第25章介绍空间和地理数据、时间数据、多媒体数据以及移动和个人数据库管理中的问题。
最后,第26章讨论高级事务处理。这一章的内容包括事务处理监控器、事务工作流、电子商务、高性能事务系统、实时事务系统和持续长时间的事务。
第九部分:实例研究(第27章至第30章)。在这一部分我们对四个领先的数据库系统进行实例研究,包括PostgreSQL、Oracle、IBM DB2和Microsoft SQL Server。这几章中列举了上述每一种系统的独有特性,描述了它们的内部结构,提供了关于各个产品的丰富的有用信息,帮助读者了解前面各部分描述的各种实现技术是如何使用到实际系统中的。这几章中还包括实际系统设计中的几个有趣的方面。
第6版
对于本书第6版的产生起指导作用的包括我们收到的关于前面几版的许多意见和建议,我们在耶鲁大学、利哈依大学、孟买印度理工学院讲授本课程的体会,以及我们对于数据库技术发展方向的分析。
我们用一个大学的例子替换了原先的银行企业的运行例子。这个例子与学生相关,不仅有助于他们记住这个例子,而且更重要的是,使他们能够更深地洞察所需进行的各种设计决策。
我们重新组织了这本书,将我们关于SQL的介绍都集中在一起,放在本书的开头部分。第3章、第4章和第5章对SQL进行完整的介绍。第3章给出该语言的基础,而将更高级的特性放在了第4章。在第5章中,我们介绍从通用的程序设计语言访问SQL的JDBC和其他方法。我们介绍触发器和递归,最后讨论联机分析处理(OLAP)。入门性的课程可以选择只包括第5章的某些节,或者将一些节延迟到讲过了数据库设计之后再讲,这样也不失连续性。
除了这两个主要的改变外,我们修订了每一章中的素材,对旧的素材进行更新,增加对于数据库技术的新的发展的讨论,并且改进学生难于理解的那些内容的描述。我们还增加了新的练习并更新了参考文献。具体的改变如下。
较早介绍了SQL。许多讲课教师使用SQL作为课程实习的核心成分。为了给学生充足的时间做课程实习,尤其对于那些四学期制的大学和学院来说,尽早教授SQL非常重要。有了这个认识,我们在内容组织方面做了几个改动:
□ 用新的一章(第2章)介绍关系模型,放在SQL之前,打下概念基础,而不使学生迷失在关系代数的细节中。
□ 第3章、第4章和第5章详细介绍SQL。这几章还讨论不同的数据库系统支持的变体,从而当学生在实际的数据库系统上执行查询时会少遇到一些问题。这几章涵盖了SQL的所有方面,包括查询、数据定义、约束说明、OLAP和从各种语言(包括Java/JDBC)内部使用SQL。
□ 形式语言(第6章)推迟到SQL之后,而且可以略掉不讲,而不会影响其他章的顺序。只有在第13章关于查询优化的讨论依赖于第6章介绍的关系代数。
新的数据库模式。我们采用了一个新的模式作为贯穿全书的运行实例,基于大学的数据。对于学生来说,这个模式比以前的银行模式更加直观和有意义,而且在数据库设计的章节中展示了更复杂的设计权衡。
对学生的亲手实践提供了更多的支持。为了推动学生跟着我们的运行实例进行实践,我们在附录A中列出了大学数据库的数据库模式和样例的关系实例,并在用到大学实例的各个章中也进行了说明。另外,在我们的Web站点http://www.dbbook.com上,提供了对于整个例子的SQL数据定义语句,以及建立我们的样例关系实例的SQL语句。这鼓励了学生直接在一个实际的数据库系统中去运行样例查询,并且试着去修改这些查询。
修订了对ER模型的涵盖。我们修改了第7章中ER图的符号表示,以使得它与UML更兼容。这一章还充分利用了新的大学数据库模式来描述更复杂的设计权衡。
修订了对关系设计的涵盖。第8章的风格现在更具可读性,它在阐述函数依赖理论之前提供了对函数依赖和规范化的一个直观的理解,其结果是理论的动机更清晰了。
扩充了关于应用开发和安全性的素材。第9章包括了关于应用开发的新的素材,以反映该领域的快速变化。特别地,扩展了关于安全性的介绍,包括它在当今紧密互联的世界中的至关重要性,并重点强调了抽象概念外的实际问题。
修订和更新了对数据存储、索引和查询优化的涵盖。对第10章进行了新技术方面的更新,包括对闪存的更多的讨论。
更新了第11章对B+树的讨论,以反映实际的实现,包括对批量载入的介绍,并且对陈述方式也进行了改进。第11章中B+树的例子修改成了n=4,以避免(不切实际的)n=3时发生的空结点的特殊情况。
第13章中有关于高级查询优化技术的新的素材。
修订了对事务管理的涵盖。第14章全面涵盖了入门性课程中的基础知识,而高级的细节在第15章和第16章中介绍。我们扩展了第14章,以涵盖数据库用户和数据库应用开发人员所面对的事务管理的实际问题。这一章还包括了对第15章和第16章所讨论话题的扩展的综述,以确保即使略掉第15章和第16章,学生仍能对并发控制和恢复的概念有基本的了解。
第14章和第15章现在包括了对当今被广泛支持和使用的快照隔立性的详细介绍,对于使用它的潜在风险也做了介绍。
第16章现在对基本的基于日志的恢复进行了简化的描述,进一步介绍了ARIES算法。
修订和扩充了对分布式数据库的涵盖。我们现在涵盖了云数据存储,它在商业应用中正日益受到极大的重视。云存储为企业提供了改进成本管理和增加存储可扩充性的机遇,特别是对于基于Web的应用。我们分析了这些优点,也指出了可能的缺点和风险。
我们原来在高级事务处理这一章中讨论多数据库,现在对它更早地进行了介绍,作为分布式数据库这一章中的一部分。
推迟了对对象数据库和XML的介绍。虽然面向对象的语言和XML在数据库的范围之外被广泛使用,但在数据库中的使用仍然有限,这使得它们对于高级课程或作为入门性课程的补充材料更适合一些。因此这些话题在本书中向后移了,放到了第22章和第23章。
QBE、Microsoft Access和Datalog放在联机附录中。这些话题原来是“其他关系语言”这一章中的一部分,现在放在联机附录C中了。
上面没有列出的所有话题都在第5版的基础上做了更新,虽然相对地它们的总体组织没有改变。
回顾材料和习题
每一章都有一个术语回顾表,还有一个总结,这可以帮助读者回顾这一章中涵盖的关键话题。
练习划分成两部分:实践习题(practice exercise)和习题(exercise)。实践习题的解答在本书的Web站点公开发布。我们鼓励学生独立解决这些实践习题,然后用Web站点上的解答来检查自己的答案。其他练习题的解答只有讲课教师能得到(参看下面的“讲课教师注意事项”以获取如何得到题解的信息)。
许多章的末尾有一个“工具”节,它提供与该章的话题相关的软件工具的信息;这些工具中的一些可以用于实验室练习。大学数据库和习题中用到的其他关系的SQL DDL和样例数据在本书的Web站点可以得到,也可以用于实验室练习。
讲课教师注意事项
本书包括基本内容和高级内容,在一个学期内也许不能讲授所有这些内容。我们以符号“**”把某些节标记为高级内容,如果愿意的话可以省略这些节,而仍能保持内容的连续性。较难的(可以忽略的)练习同样用符号“**”标记出来了。
可以用本书各章的不同子集来设计课程。某些章也可以用不同于本书中的顺序来讲授。我们列出一些可能的安排如下:
第5章可以跳过或推迟到后面讲,而不失连续性。我们期望大多数的课程至少5.1.1节较早地讲授,因为JDBC很可能会是学生实习的一个有用工具。
第6章可以在第2章之后、讲SQL之前讲。也可以把这一章从入门性的课程中省略掉。
我们建议如果课程中讲查询处理的话,那么把6.1节也包括在课程中。但是,如果学生在课程中不使用关系演算的话,那么6.2节和6.3节可以省略。
如果教师愿意的话,第7章可以在第3章、第4章和第5章之前讲,因为第7章完全不依赖于SQL。
第13章可以从入门性的课程中省略掉,而对于其他任何章的讲授都没有影响。
我们对事务处理的讨论(第14章至第16章)和对系统体系结构的讨论(第17章至第19章)都包括一章综述(分别为第14章和第17章)和后续的两章详细讨论。如果计划把后面几章推迟到高级课程中去讲授,可以选择使用第14章和第17章,省略第15章、第16章、第18章和第19章。
发表评论
-
【互动出版网】2013双12全场科技类图书6.5折封顶
2013-12-12 16:30 1142【互动出版网】2013双12全场科技类图书6.5折封顶 ... -
C#编程兵书
2013-08-28 17:43 1205《C#编程兵书》 基本信息 作者: 张志强 胡君 丛书 ... -
C++编程兵书
2013-08-28 17:24 1221《C++编程兵书》 基本 ... -
HTML+CSS网站开发兵书
2013-08-28 17:04 1407《HTML+CSS网站开发兵书 ... -
Java编程兵书
2013-08-27 17:57 1229《Java编程兵书》 基本 ... -
网络运维与管理2013超值精华本
2013-08-27 17:44 1350《网络运维与管理2013超值精华本》 基本信息 作者: ... -
HTML5游戏开发进阶指南
2013-08-27 17:26 1326《HTML5游戏开发进阶指 ... -
ASP.NET MVC 4高级编程(第4版)
2013-08-26 17:58 1097《ASP.NET MVC 4高级编程(第4版)》 基本信息 ... -
嗨翻C语言
2013-08-26 17:40 1175《嗨翻C语言》 基本信息 作者: (美)David Gr ... -
C++ Primer中文版(第5版)
2013-08-26 17:20 1142《C++ Primer中文版(第5版) 》 基本信息 作 ... -
云计算原理与实践
2013-08-20 17:02 577《云计算原理与实践》 基本信息 作者: 游小明 罗光春 ... -
微信公众平台搭建与开发揭秘
2013-08-20 16:53 994《微信公众平台搭建与开发揭秘》 基本信息 作者: 易伟 ... -
精通iOS开发(第5版)
2013-08-20 16:25 1038《精通iOS开发(第5版)》 基本信息 原书名:Begi ... -
企业门户(Portal)项目实施方略与开发指南
2013-08-20 16:12 968《企业门户(Portal)项目实施方略与开发指南》 基本信 ... -
Java开发手册
2013-08-20 15:56 944《Java开发手册》 基本信息 作者: 桂颖 谷涛 出 ... -
Unity3D手机游戏开发
2013-08-08 17:33 1132《Unity3D手机游戏开发》 基本信息 作者: 金玺曾 ... -
矛与盾:黑客攻防命令大曝光
2013-08-08 16:30 770《矛与盾:黑客攻防命令大曝光》 基本信息 作者: awk ... -
视觉繁美:信息可视化方法与案例解析
2013-08-08 16:10 927《视觉繁美:信息可视 ... -
精益设计: 设计团队如何改善用户体验
2013-08-08 15:55 768《精益设计: 设计团队如何改善用户体验》 基本信息 原书 ... -
云计算与OpenStack(虚拟机Nova篇)
2013-08-08 15:19 948《云计算与OpenStack(虚拟机Nova篇)》 基本信 ...
相关推荐
《数据库系统概念》是一本深入探讨数据库理论与实践的经典教材,涵盖了数据库设计、管理、查询以及优化等核心领域。这本书籍对于理解数据库的工作原理、掌握SQL语言以及在实际项目中应用数据库技术至关重要。 ...
1. 王珊《数据库系统概论》(第四版) 2. 闪四清《数据库系统原理与应用教程》 3. 周龙骧《数据库管理系统实现技术》 4. 张海藩《软件工程概论》 5. 陈明《实用软件工程基础》 6. 成先海《数据库基础与应用-SQL ...
根据提供的信息,《数据库系统概念》(Database System Concepts)是一本重要的计算机科学领域的教材,主要介绍了数据库系统的各个方面。这本书由Silberschatz、Korth和Sudarshan编写,并且是第四版。以下是从该书籍...
综上所述,"数据库系统概念第六版课后习题部分答案.zip"这份资料对于数据库的学习者来说,是一个不可多得的学习资源。它不仅有助于个人学习,也是团队学习、交流和提升的重要基础。通过这些习题和解答,学习者可以更...
《数据库系统---设计、实现与管理(第四版英文版)》是一本在IT教育领域内广受认可的教材,它系统地讲解了数据库相关的知识,旨在为初学者和希望深入理解数据库技术的专业人员提供学习资源。这本书涵盖了数据库设计...
《数据库系统原理》原书是王珊和陈红编写的,由清华大学出版社于1998年7月出版的书籍,属于计算机科学与技术领域,主要探讨了数据库系统的核心原理和相关技术。本书是数据库系统原理的经典教材,详细介绍了数据库...
《数据库系统概念》是数据库领域的经典教材,第六版更是涵盖了最新的理论和技术发展。这份配套PPT是教师在课堂上实际使用的教学资料,旨在帮助学生深入理解数据库系统的概念、设计和管理。以下是对其中可能涉及的...
数据库系统工程师教程是一本深入探讨数据库技术的专业书籍,旨在帮助读者掌握数据库设计、管理、优化以及故障排除等关键技能。数据库作为现代信息系统的核心组件,其重要性不言而喻,因此,理解并熟练掌握数据库系统...
本实验是基于郑阿奇版SQL Server教材的第12章设计的,旨在提供一个功能完善的图书管理系统。该系统利用数据库技术,实现了对图书借阅、归还以及借阅记录的全面管理,同时包含了学生信息的高效管理。以下是关于这个...
综上所述,"图书管理系统MySQL数据库"不仅涵盖了数据库设计、关系模型、索引、事务处理等基础概念,还包括了性能优化、安全性和扩展性等高级话题。理解和掌握这些知识点,对于构建高效、稳定的图书管理系统至关重要...
《数据库图书管理系统完整版的Java项目》是一款基于Java技术实现的图书管理软件,它涵盖了图书馆管理的核心功能,为用户提供了一套高效、完善的图书资源管理解决方案。这个系统充分体现了Java语言在开发企业级应用中...
Abraham Silberschatz Yale University Henry F. Korth Lehigh University S. Sudarshan Indian Institute of Technology, Bombay TM编写的书籍以及答案
数据库系统概念(中文版)(第6版)1 数据库系统概念是指对数据进行存储、管理、处理和维护的软件系统,是现代计算环境中的一个核心成分。该书籍旨在讲述数据库系统的基本概念,包括数据库设计、数据库语言、数据库...
这本书的第五版提供了全面而深入的数据库理论知识,涵盖了从基础概念到高级特性的广泛内容,旨在帮助读者理解并掌握数据库设计、管理与应用的核心技术。 在本书中,读者可以学习到以下关键知识点: 1. **数据库...
《图书管理系统源码+数据库》是一个基于Struts1.x框架和JDBC技术实现的软件项目。这个系统的主要目的是为了提供一套高效、便捷的图书管理解决方案,涵盖了图书的入库、出库、借阅、归还以及相关统计分析等功能。下面...
如库存管理系统、物资采购系统、作业调度系统、设备管理系统、人事管理系统等),学校的学生管理系统,人事管理系统,图书馆的图书管理系统,等等,都适合用数据库系统。 数据库系统的特点 数据库系统的主要特点有...
数据库系统概论电子书仅供大家学习参考,下载好用