第1章 数据库系统 1
1.1 数据库系统概述 1
1.1.1 基本概念 1
1.1.2 数据管理技术的发展 2
1.1.3 数据库系统的组成 5
1.1.4 数据库技术的研究领域 7
1.2 数据库系统的结构 8
1.2.1 数据库系统的体系结构 8
1.2.2 数据库系统的模式结构 9
1.2.3 数据库系统的三级模式结构 10
1.2.4 数据库的两级映像功能与数据独立性 11
1.3 数据模型 12
1.3.1 信息的三种世界 13
1.3.2 概念模型 14
1.3.3 常用的数据模型 16
1.4 数据库管理系统 18
习题1 20
第2章 关系数据库 22
2.1 关系模型 22
2.2 关系模式及其描述 24
2.2.1 关系的形式化定义 24
2.2.2 关系模式及关系数据库 25
2.3 关系的完整性 27
2.3.1 实体完整性 27
2.3.2 参照完整性 27
2.3.3 用户定义的完整性 28
2.4 关系代数 28
2.4.1 传统的集合运算 29
2.4.2 专门的关系运算 30
2.5 关系系统的十二条准则 35
2.6 关系系统的查询优化 38
2.6.1 查询处理及查询优化 38
2.6.2 等价规则 40
2.6.3 查询策略选择算法 41
2.6.4 查询优化技术 41
习题2 42
第3章 关系数据库标准语言SQL 46
3.1 SQL概述及特点 46
3.1.1 SQL语言的发展 46
3.1.2 SQL数据库的体系结构 47
3.1.3 SQL语言的特点 48
3.1.4 SQL的数据类型 49
3.2 SQL的数据定义 51
3.2.1 基本表的定义与维护 51
3.2.2 索引的定义和维护 56
3.3 SQL的数据查询 58
3.3.1 简单查询 58
3.3.2 连接查询 64
3.3.3 嵌套查询 66
3.3.4 集合查询 69
3.4 SQL的数据更新 70
3.4.1 插入数据 70
3.4.2 修改数据 71
3.4.3 删除数据 72
3.5 视图 72
3.5.1 视图的概念及作用 72
3.5.2 视图的定义与维护 73
3.5.3 视图的操作 75
3.5.4 使用视图的限制 75
3.6 SQL的数据控制功能 76
3.6.1 权限与角色 76
3.6.2 授予权限 77
3.6.3 收回权限 79
3.7 嵌入式SQL 80
3.7.1 嵌入式SQL的实现方式 80
3.7.2 嵌入式SQL的使用规定 81
3.7.3 嵌入式SQL的使用技术 83
习题3 85
第4章 关系数据库理论 90
4.1 问题的提出 90
4.2 函数依赖 92
4.2.1 函数依赖的定义 92
4.2.2 函数依赖的分类 93
4.2.3 键 94
4.3 关系模式的规范化 95
4.3.1 关系与范式 95
4.3.2 第一范式 95
4.3.3 第二范式 96
4.3.4 第三范式 97
4.3.5 BC范式 98
4.3.6 多值依赖与第4范式 99
4.3.7 规范化小结 101
4.4 函数依赖的公理系统 102
4.4.1 Armstrong公理系统 103
4.4.2 Armstrong公理的完备性 104
4.4.3 属性集闭包的计算 105
4.4.4 函数依赖集的等价与最小函数依赖集 106
4.5 关系模式的分解 107
4.5.1 等价模式分解的定义 107
4.5.2 无损连接的分解 108
4.5.3 保持函数依赖的分解 111
4.5.4 模式分解的算法 112
习题4 115
第5章 数据库的控制 118
5.1 数据库的安全性 118
5.1.1 数据库安全性的含义 118
5.1.2 安全性控制的一般方法 118
5.2 数据库的完整性 121
5.2.1 完整性控制的含义 121
5.2.2 完整性约束条件 122
5.2.3 完整性控制 124
5.2.4 完整性的实现方法 127
5.3 数据库的并发控制 129
5.3.1 事务概述 129
5.3.2 并发操作与数据的不一致性 130
5.3.3 封锁及封锁协议 132
5.3.4 活锁与死锁问题 135
5.3.5 并发调度的可串行性 137
5.4 数据库的恢复 140
5.4.1 数据库故障种类 140
5.4.2 数据库恢复的技术 142
5.4.3 数据库恢复策略 144
5.4.4 具有检查点的数据恢复技术 145
习题5 147
第6章 数据库系统设计 150
6.1 数据库系统设计概述 150
6.1.1 数据库系统设计的目标、特点和方法 150
6.1.2 数据库设计的步骤 151
6.2 需求分析 153
6.2.1 需求分析的任务 153
6.2.2 需求分析的方法 154
6.2.3 数据流图 156
6.2.4 数据字典 158
6.3 概念结构设计 161
6.3.1 概念结构设计的方法和步骤 161
6.3.2 E-R图 162
6.3.3 局部视图设计 169
6.3.4 E-R图的集成 172
6.4 逻辑结构设计 175
6.4.1 逻辑结构设计的步骤 175
6.4.2 E-R图向关系模型的转换 176
6.4.3 模型的优化 179
6.4.4 子模式设计 179
6.5 数据库物理设计 180
6.5.1 物理设计的内容和方法 180
6.5.2 确定物理结构 181
6.5.3 评价物理结构 183
6.6 数据库实施与维护 183
6.6.1 数据库实施 183
6.6.2 数据库运行和维护 185
习题6 186
第7章 关系数据库管理系统SQL Server 2000 188
7.1 SQL Server 2000基础 188
7.1.1 SQL Server的性能 188
7.1.2 SQL Server体系结构 190
7.1.3 SQL Server 2000的配置与安装 191
7.2 SQL Server 2000的主要组件 199
7.2.1 企业管理器 199
7.2.2 查询分析器 200
7.2.3 服务管理器 201
7.2.4 其他组件 201
7.3 SQL Server 2000数据库操作 202
7.3.1 SQL Server数据库的基本概念 202
7.3.2 创建和维护数据库 205
7.3.3 在企业管理器中创建和维护表 210
7.3.4 视图的定义和维护 216
7.3.5 存储过程定义和维护 221
7.3.6 触发器的定义和维护 225
7.4 SQL Server 2000数据库备份 228
7.4.1 数据库备份 229
7.4.2 还原数据库 230
7.5 数据转换服务DTS 233
7.5.1 数据导入 233
7.5.2 数据导出 234
7.6 SQL Server 2000安全管理 235
7.6.1 SQL Server的安全体系 236
7.6.2 SQL Server的安全认证模式 236
7.6.3 SQL Server的用户和角色的管理 239
7.6.4 SQL Server的角色 243
7.6.5 SQL Server的权限问题 246
习题7 250
第8章 数据库应用系统开发环境和工具 253
8.1 数据库应用程序的体系结构 253
8.1.1 数据库应用程序体系结构的发展 253
8.1.2 数据库应用程序开发环境 255
8.1.3 数据库应用程序开发工具 257
8.2 数据库访问技术 258
8.2.1 数据库应用程序开发接口 258
8.2.2 开放数据库互连ODBC 259
8.3 使用Visual Basic访问数据库 264
8.3.1 数据访问对象DAO 264
8.3.2 使用ADO模型访问SQL Server数据库 265
习题8 268
第9章 数据库系统的实验 270
9.1 实验准备 270
9.2 实验安排 270
9.2.1 管理工具的使用及数据库的定义 270
9.2.2 SQL数据查询与更新 271
9.2.3 数据库的备份与恢复、数据的导入与导出 272
9.2.4 安全性管理 272
9.2.5 数据库的完整性实现 273
9.2.6 视图、存储过程及触发器的创建与执行 274
9.2.7 简单应用系统的实现 275