第1章 数据库系统概述 1
1.1 引言 1
1.1.1 数据库是计算机技术发展的产物 1
1.1.2 数据库是计算机应用的基础 1
1.1.3 Access数据库是中小型数据库的最佳选择 1
1.1.4 Access数据库系统是企业级开发工具 2
1.2 数据库技术的发展 2
1.2.1 数据库发展阶段的划分 2
1.2.2 人工管理阶段 2
1.2.3 文件系统阶段 3
1.2.4 数据库系统阶段 3
1.2.5 高级数据库阶段 6
1.2.6 数据库应用的体系结构 9
1.3 数据模型 9
1.3.1 数据模型 10
1.3.2 概念模型 10
1.3.3 概念模型的表示方法-实体联系模型 11
1.3.4 几种常见的逻辑模型 14
1.4 数据库系统结构 17
1.4.1 数据库系统的三级模式结构 17
1.4.2 数据库系统的组成 18
1.5 数据库管理系统的功能及工作过程 19
1.5.1 数据库管理系统的主要功能 19
1.5.2 数据库系统的工作过程 20
1.5.3 数据库系统的不同视图 21
1.6 小结 22
习题 22
第2章 关系数据库数学模型 27
2.1 关系模型的基本概念 27
2.1.1 关系的数学定义 27
2.1.2 关系模型 29
2.2 EER模型到关系模型的转换 30
2.2.1 实体类型的转换 30
2.2.2 二元关系的转换 31
2.2.3 实体内部之间联系的转换 32
2.2.4 三元关系的转换 33
2.2.5 子类型的转换 33
2.3 关系代数 34
2.3.1 基于传统集合理论的关系运算 34
2.3.2 专门的关系运算 35
2.4 关系演算 39
2.4.1 元组关系演算 40
2.4.2 域关系演算 42
2.5 小结 43
习题 43
第3章 关系数据库设计理论 51
3.1 问题的提出 51
3.2 函数依赖 52
3.2.1 数据依赖 52
3.2.2 函数依赖 52
3.2.3 函数依赖的逻辑蕴涵 53
3.2.4 键 53
3.3 关系模式的规范化 54
3.3.1 第一范式(1NF) 55
3.3.2 第二范式(2NF) 56
3.3.3 第三范式(3NF) 57
3.3.4 BCNF范式 57
3.3.5 多值函数依赖 58
3.3.6 第四范式(4NF) 61
3.4 函数依赖的公理系统 62
3.4.1 Armstrong公理 62
3.4.2 公理的正确性 62
3.4.3 公理的推论 63
3.5 模式分解 63
3.5.1 无损连接 63
3.5.2 保持函数依赖的分解 65
3.5.3 3NF无损连接和保持函数依赖的分解算法 66
3.6 闭包及其计算* 66
3.7 函数依赖集的等价和覆盖* 68
3.8 公理的完备性* 70
3.9 小结 71
习题 71
第4章 Access数据库设计 75
4.1 数据库设计的总体思路 75
4.2 建立数据库 76
4.3 数据表的建立 78
4.4 使用数据表向导创建表 78
4.5 通过输入数据建立新表 80
4.6 使用表的“设计”视图 81
4.6.1 数据表设计窗体 83
4.6.2 数据表窗体中的工具栏 83
4.6.3 建立和命名字段 83
4.6.4 指定字段的数据类型 83
4.6.5 字段说明 85
4.6.6 字段属性的设置 85
4.6.7 定义主关键字 85
4.6.8 为需要的字段建立索引 86
4.7 更改数据表的结构 86
4.7.1 移动字段的位置 86
4.7.2 添加新字段 87
4.7.3 删除字段 87
4.7.4 更改字段名称 87
4.7.5 更改字段大小 87
4.7.6 更改字段的数据类型 88
4.8 保存完成的数据表 89
4.9 数据表关联 89
4.9.1 如何定义表间的关系 89
4.9.2 编辑已有的关系 91
4.9.3 删除关系 91
4.9.4 查看已有的关系 91
4.9.5 设置参照完整性 92
4.9.6 联系类型 92
4.10 小结 92
上机题 93
习题 94
第5章 数据查询 104
5.1 认识查询 104
5.1.1 查询的目的 104
5.1.2 查询的种类 104
5.1.3 查询准则 105
5.2 创建选择查询 106
5.3 创建交叉表查询 108
5.4 创建参数查询 110
5.5 创建动作查询 112
5.5.1 生成表查询 112
5.5.2 删除查询 113
5.5.3 追加查询 114
5.5.4 更新查询 115
5.6 保存查询 117
5.7 小结 117
上机题 117
习题 118
第6章 使用高级查询——SQL语言 123
6.1 SQL的数据定义 123
6.1.1 基表 123
6.1.2 索引 124
6.2 SQL的数据操纵 125
6.2.1 查询 125
6.2.2 插入 130
6.2.3 删除 131
6.2.4 更新 131
6.3 视图 132
6.3.1 视图的建立和撤销 132
6.3.2 视图的操作 133
6.3.3 视图的优点 133
6.4 小结 134
上机题 134
习题 135
第7章 窗体设计 141
7.1 认识数据输入的窗体 141
7.1.1 窗体的结构 141
7.1.2 窗体的种类 142
7.2 窗体的用途 143
7.3 建立窗体 143
7.4 窗体窗口介绍 144
7.4.1 窗体的工具栏 144
7.4.2 窗体弹出式菜单 144
7.4.3 “设计视图”窗体中的工具箱 145
7.5 窗体属性、控件属性及节的属性 146
7.6 将图片或其他OLE对象添加到窗体中 147
7.7 定制窗体的外观 147
7.7.1 文本 147
7.7.2 设置窗体属性 147
7.7.3 在窗体中添加当前日期和时间 148
7.7.4 设置控件属性 148
7.8 使用计算性表达式 149
7.9 在窗体中使用宏 150
7.10 设置值 150
7.10.1 改变当前的控件焦点、页号和记录号 151
7.10.2 查找记录 151
7.10.3 显示提示信息 151
7.10.4 打印窗体 151
7.10.5 利用宏来引入和导出数据 151
7.10.6 设计菜单 152
7.11 创建与使用主/子窗体 152
7.11.1 同时创建主窗体和子窗体 153
7.11.2 创建子窗体并将其添加到已有的窗体中 154
7.12 小结 156
上机题 156
习题 157
第8章 建立和打印报表 162
8.1 认识报表的用途 162
8.2 报表的结构组成 162
8.3 报表设计区 163
8.3.1 报表页眉 163
8.3.2 页面页眉 164
8.3.3 群组页眉 164
8.3.4 主体 164
8.3.5 群组页脚 165
8.4 报表的分类 165
8.4.1 群组/合计报表 165
8.4.2 纵栏式报表 166
8.4.3 邮件标签 166
8.5 认识报表窗体 166
8.5.1 预览窗体中的工具栏 167
8.5.2 报表设计窗体中工具栏和工具箱 167
8.6 设计报表 167
8.6.1 用预定义格式来设置报表的格式 167
8.6.2 添加分页符和页码 168
8.6.3 在报表上使用节 169
8.6.4 在报表上绘制线条 169
8.6.5 在报表上绘制矩形 170
8.7 制作图表 170
8.8 创建子报表 171
8.8.1 子报表的定义和作用 171
8.8.2 在已有报表中创建子报表 172
8.8.3 将某个已有报表添加到其他已有报表来创建子报表 173
8.8.4 链接主报表和子报表 173
8.8.5 更改子报表的布局 174
8.9 创建多列报表 174
8.10 设计复杂的报表 175
8.10.1 报表属性 175
8.10.2 节属性 176
8.10.3 使用选项组显示选项 176
8.10.4 给报表添加分页符 176
8.11 打印预览报表 177
8.12 小结 177
上机题 177
习题 177
第9章 Web页 180
9.1 概述 180
9.2 使用向导创建数据访问页 180
9.3 使用设计器创建和修改数据访问页 183
9.3.1 使用设计器创建数据访问页 183
9.3.2 使用“设计”视图修改数据访问页 186
9.4 小结 187
上机题 187
习题 187
第10章 宏操作 189
10.1 宏的概念 189
10.2 宏的分类 190
10.3 宏窗体中的工具栏 191
10.4 宏动作 192
10.5 创建宏 193
10.6 在宏中设置操作参数的提示 194
10.7 创建宏组 195
10.8 宏的条件表达式 195
10.9 执行宏 196
10.10 调试宏 196
10.11 宏的触发 198
10.12 小结 198
上机题 198
习题 200
第11章 面向对象程序设计语言——VBA 202
11.1 VBA概述 202
11.1.1 为什么要使用VBA 202
11.1.2 VBA简介 202
11.1.3 VBA与xBase、PAL和Visual Basic的比较 202
11.1.4 如何使用Visual Basic程序代码 203
11.2 模块的定义和使用 203
11.2.1 模块的概念 203
11.2.2 模块的定义和使用 206
11.3 VBA程序设计概念和书写原则 207
11.3.1 集合和对象 207
11.3.2 属性和方法 207
11.3.3 事件和事件过程 208
11.3.4 程序语句书写原则 208
11.4 Visual Basic的数据类型与数据库对象 208
11.5 变量 210
11.5.1 隐含型变量 210
11.5.2 显式的变量 210
11.5.3 变量的作用域与生命周期 210
11.5.4 用户定义的数据类型 211
11.5.5 Visual Basic数组 211
11.6 将数据库对象命名为VBA程序代码中的变量 212
11.7 变量命名的法则 213
11.8 符号常量 213
11.9 Access系统定义的常量 214
11.10 Access固有常量 214
11.11 Access常用标准函数 214
11.11.1 算术函数 214
11.11.2 字符串函数 215
11.11.3 日期/时间函数 216
11.11.4 类型转换函数 219
11.12 运算符和表达式 219
11.12.1 运算符 219
11.12.2 表达式和优先级 220
11.13 程序控制流程 221
11.13.1 以GoTo转移程序控制 221
11.13.2 条件语句 221
11.13.3 循环 223
11.14 处理执行时的错误 225
11.15 VBA的基本操作 226
11.15.1 打开和关闭窗体和报表对象 226
11.15.2 信息输入和消息输出 228
11.15.3 数据验证 230
11.15.4 计时事件Timer和动画处理 230
11.15.5 鼠标和键盘事件处理 231
11.15.6 文件操作 232
11.16 简单数据库编程 238
11.16.1 数据库编程技术简介 238
11.16.2 数据库编程技术分析 240
11.16.3 Docmd.RunSQL方法运用 248
11.17 小结 250
上机题 250
习题 251
第12章 复杂数据库设计 261
12.1 数据库设计概述 261
12.1.1 数据库设计的内容和要求 261
12.1.2 数据库设计过程 263
12.2 需求分析 265
12.2.1 确认用户需求,确定设计范围 265
12.2.2 收集和分析需求数据 265
12.2.3 需求说明书 266
12.3 概念设计 266
12.3.1 设计局部概念模式 267
12.3.2 设计全局概念模式 268
12.4 逻辑设计 270
12.5 物理设计 271
12.6 数据库的建立和维护 272
12.6.1 建立数据库 272
12.6.2 数据库的重组织和重构造 272
12.7 小结 273
习题 274