第1章 初识Oracle 1
1.1 数据库基础 1
1.1.1 什么是数据库 1
1.1.2 表 2
1.1.3 数据类型 2
1.1.4 主键 2
1.2 数据库技术构成 3
1.2.1 数据库系统 3
1.2.2 SQL语言 4
1.2.3 数据库访问技术 5
1.3 什么是Oracle 12c 5
1.3.1 Oracle的发展历程 6
1.3.2 Oracle 12c版本的新功能 7
1.3.3 Oracle的优势 8
1.4 Oracle工具 9
1.4.1 SQL Plus 9
1.4.2 Oracle SQL Developer 10
1.5 如何学习Oracle 11
第2章 Oracle的安装与配置 12
2.1 安装Oracle 12c 12
2.2 启动服务并登录Oracle数据库 18
2.2.1 启动Oracle服务 18
2.2.2 登录Oracle数据库 20
2.3 卸载Oracle 12c 24
2.4 疑难解惑 27
2.5 经典习题 30
第3章 数据库和数据表的基本操作 31
3.1 创建数据库 31
3.2 删除数据库 34
3.3 创建数据表 38
3.3.1 创建数据表的语法形式 38
3.3.2 使用主键约束 39
3.3.3 使用外键约束 41
3.3.4 使用非空约束 43
3.3.5 使用唯一性约束 44
3.3.6 使用默认约束 45
3.3.7 使用检查约束 46
3.3.8 设置表的属性值自动增加 47
3.4 查看数据表结构 48
3.5 修改数据表 49
3.5.1 修改表名 49
3.5.2 修改字段的数据类型 50
3.5.3 修改字段名 51
3.5.4 添加字段 51
3.5.5 删除字段 52
3.6 删除数据表 53
3.6.1 删除没有被关联的表 53
3.6.2 删除被其他表关联的主表 54
3.7 综合案例——数据表的基本操作 55
3.8 疑难解惑 61
3.9 经典习题 63
第4章 数据类型和运算符 65
4.1 Oracle数据类型介绍 65
4.1.1 数值类型 65
4.1.2 日期与时间类型 67
4.1.3 字符串类型 70
4.2 如何选择数据类型 71
4.3 常见运算符介绍 72
4.3.1 运算符概述 72
4.3.2 算术运算符 72
4.3.3 比较运算符 74
4.3.4 逻辑运算符 75
4.3.5 运算符的优先级 76
4.4 疑难解惑 77
4.5 经典习题 78
第5章 Oracle函数 79
5.1 Oracle函数简介 79
5.2 数学函数 79
5.2.1 绝对值函数ABS(x) 80
5.2.2 平方根函数SQRT(x)和求余函数MOD(x,y) 80
5.2.3 获取整数的函数CEIL(x)和FLOOR(x) 80
5.2.4 获取随机数的函数DBMS_RANDOM.RANDOM和DBMS_RANDOM.VALUE(x,y) 81
5.2.5 函数ROUND(x)、ROUND(x,y)和TRUNC(x,y) 81
5.2.6 符号函数SIGN(x) 83
5.2.7 幂运算函数POWER(x,y)和EXP(x) 83
5.2.8 对数运算函数LOG(x,y)和LN(x) 83
5.2.9 正弦函数SIN(x)和反正弦函数ASIN(x) 84
5.2.10 余弦函数COS(x)和反余弦函数ACOS(x) 84
5.2.11 正切函数TAN(x)和反正切函数ATAN(x) 85
5.3 字符串函数 85
5.3.1 计算字符串长度的函数 85
5.3.2 合并字符串函数CONCAT(s1,s2) 86
5.3.3 字符串搜索函数INSTR(s,x) 86
5.3.4 字母大小写转换函数 86
5.3.5 获取指定长度的字符串的函数SUBSTR(s,m,n) 87
5.3.6 替换字符串的函数REPLACE(s1,s2,s3) 87
5.3.7 删除字符串首尾指定字符的函数LTRIM(s,n)和RTRIM(s,n) 88
5.3.8 删除指定字符串的函数TRIM() 88
5.3.9 字符集名称和ID互换函数 89
5.4 日期和时间函数 89
5.4.1 获取当前日期和时间的函数 89
5.4.2 获取时区的函数 90
5.4.3 获取指定月份最后一天的函数 90
5.4.4 获取指定日期后一周的日期的函数 91
5.4.5 获取指定日期特定部分的函数 91
5.4.6 获取两个日期之间的月份数的函数 91
5.5 转换函数 92
5.5.1 字符串转ASCII类型字符串函数 92
5.5.2 二进制转十进制函数 92
5.5.3 数据类型转换函数 92
5.5.4 数值转换为字符串函数 93
5.5.5 字符转日期函数 93
5.5.6 字符串转数字函数 94
5.6 系统信息函数 94
5.6.1 返回登录名函数 94
5.6.2 返回会话以及上下文信息函数 94
5.7 综合案例——Oracle函数的使用 95
5.8 疑难解惑 97
5.9 经典习题 98
第6章 查询数据 99
6.1 基本查询语句 99
6.2 单表查询 102
6.2.1 查询所有字段 102
6.2.2 查询指定字段 103
6.2.3 查询指定记录 105
6.2.4 带IN关键字的查询 107
6.2.5 带BETWEEN AND的范围查询 108
6.2.6 带LIKE的字符匹配查询 110
6.2.7 查询空值 111
6.2.8 带AND的多条件查询 113
6.2.9 带OR的多条件查询 114
6.2.10 查询结果不重复 115
6.2.11 对查询结果排序 117
6.2.12 分组查询 121
6.2.13 使用ROWNUM限制查询结果的数量 127
6.3 使用聚合函数查询 127
6.3.1 COUNT()函数 128
6.3.2 SUM()函数 129
6.3.3 AVG()函数 130
6.3.4 MAX()函数 130
6.3.5 MIN()函数 132
6.4 连接查询 133
6.4.1 内连接查询 133
6.4.2 外连接查询 137
6.4.3 复合条件连接查询 139
6.5 子查询 140
6.5.1 带ANY、SOME关键字的子查询 140
6.5.2 带ALL关键字的子查询 141
6.5.3 带EXISTS关键字的子查询 141
6.5.4 带IN关键字的子查询 143
6.5.5 带比较运算符的子查询 145
6.6 合并查询结果 146
6.7 为表和字段取别名 150
6.7.1 为表取别名 150
6.7.2 为字段取别名 151
6.8 使用正则表达式查询 153
6.8.1 查询以特定字符或字符串开头的记录 154
6.8.2 查询以特定字符或字符串结尾的记录 155
6.8.3 用符号“.”来替代字符串中的任意一个字符 155
6.8.4 使用“*”和“+”来匹配多个字符 156
6.8.5 匹配指定字符串 156
6.8.6 匹配指定字符中的任意一个 158
6.8.7 匹配指定字符以外的字符 159
6.8.8 使用{n,}或者{n,m}来指定字符串连续出现的次数 159
6.9 综合案例——数据表查询操作 160
6.10 疑难解惑 168
6.11 经典习题 168
第7章 插入、更新与删除数据 170
7.1 插入数据 170
7.1.1 为表的所有字段插入数据 170
7.1.2 为表的指定字段插入数据 172
7.1.3 同时插入多条记录 173
7.1.4 将查询结果插入到表中 175
7.2 更新数据 177
7.3 删除数据 179
7.4 综合案例——记录的插入、更新和删除 181
7.5 疑难解惑 186
7.6 经典习题 187
第8章 视图 188
8.1 视图概述 188
8.1.1 视图的含义 188
8.1.2 视图的作用 189
8.2 创建视图 190
8.2.1 创建视图的语法形式 190
8.2.2 在单表上创建视图 190
8.2.3 在多表上创建视图 191
8.2.4 创建视图的视图 192
8.2.5 创建没有源表的视图 193
8.3 查看视图 193
8.4 修改视图 194
8.4.1 CREATE OR REPLACE VIEW语句修改视图 194
8.4.2 ALTER语句修改视图的约束 195
8.5 更新视图 196
8.6 删除视图 198
8.7 限制视图的数据操作 198
8.7.1 设置视图的只读属性 199
8.7.2 设置视图的检查属性 199
8.8 综合案例——视图应用 199
8.9 疑难解惑 205
8.10 经典习题 206
第9章 游标 207
9.1 认识游标 207
9.1.1 游标的概念 207
9.1.2 游标的优点 207
9.1.3 游标的分类 208
9.2 显式游标 208
9.2.1 显式游标的语法 208
9.2.2 打开游标 209
9.2.3 读取游标中的数据 209
9.2.4 关闭游标 209
9.2.5 使用显式游标的案例 209
9.2.6 使用显式游标的LOOP语句 210
9.2.7 使用BULK COLLECT和FOR语句的游标 211
9.2.8 使用CURSOR FOR LOOP语句的游标 212
9.2.9 显式游标的属性 213
9.3 隐式游标 217
9.3.1 使用隐式游标 217
9.3.2 隐式游标的属性 218
9.3.3 在游标中使用异常处理 220
9.4 综合案例——游标的综合应用 221
9.5 疑难解惑 223
9.6 经典习题 223
第10章 存储过程 224
10.1 创建存储过程 224
10.1.1 什么是存储过程 224
10.1.2 创建存储过程 225
10.2 调用存储过程 226
10.3 查看存储过程 227
10.4 存储过程的参数 227
10.4.1 无参数的存储过程 227
10.4.2 有参数的存储过程 229
10.5 修改存储过程 230
10.6 删除存储过程 231
10.7 查看存储过程的错误 231
10.8 综合案例——综合运用存储过程 232
10.9 疑难解惑 234
10.10 经典习题 234
第11章 Oracle触发器 235
11.1 创建触发器 235
11.1.1 什么是触发器 235
11.1.2 创建只有一个执行语句的触发器 236
11.1.3 创建有多个执行语句的触发器 236
11.2 查看触发器 239
11.2.1 查看触发器的名称 239
11.2.2 查看触发器的内容信息 240
11.3 触发器的使用 240
11.4 修改触发器 242
11.5 删除触发器 242
11.6 综合案例——使用触发器 243
11.7 疑难解惑 245
11.8 经典习题 245
第12章 管理表空间 246
12.1 什么是表空间 246
12.2 查看表空间 247
12.3 管理表空间 248
12.3.1 创建表空间 248
12.3.2 设置表空间的可用状态 250
12.3.3 设置表空间的读写状态 250
12.3.4 重命名表空间 251
12.3.5 删除表空间 251
12.3.6 建立大文件表空间 251
12.4 管理临时表空间 252
12.4.1 创建临时表空间 252
12.4.2 查看临时表空间 252
12.4.3 创建临时表空间组 253
12.4.4 查看临时表空间组 253
12.4.5 删除临时表空间组 254
12.5 管理数据文件 254
12.5.1 移动数据文件 254
12.5.2 删除数据文件 254
12.6 疑难解惑 255
12.7 经典习题 255
第13章 事务与锁 256
13.1 事务管理 256
13.1.1 什么是事务 256
13.1.2 事务的属性 257
13.1.3 事务管理的常用语句 257
13.1.4 事务的类型 257
13.1.5 事务的应用实例 258
13.1.6 事务的保存点 259
13.2 锁 260
13.2.1 什么是锁 261
13.2.2 锁的分类 262
13.2.3 锁的类型 262
13.2.4 锁等待和死锁 263
13.3 综合案例——死锁的案例 265
13.4 疑难解惑 265
13.5 经典习题 266
第14章 Oracle的用户管理 267
14.1 账户管理 267
14.1.1 管理账号概述 267
14.1.2 新建普通用户 268
14.1.3 修改用户信息 269
14.1.4 删除用户 270
14.2 权限管理 270
14.2.1 授权 270
14.2.2 收回权限 271
14.2.3 查看权限 272
14.3 角色管理 273
14.3.1 角色概述 273
14.3.2 创建角色 273
14.3.3 设置角色 274
14.3.4 修改角色 275
14.3.5 查看角色 275
14.3.6 删除角色 275
14.4 管理概要文件PROFILE 276
14.4.1 PROFILE概述 276
14.4.2 创建概要文件 276
14.4.3 修改概要文件 277
14.4.4 删除概要文件 277
14.5 疑难解惑 277
14.6 经典习题 278
第15章 控制文件和日志 279
15.1 控制文件简介 279
15.2 控制文件的应用案例 280
15.2.1 查看控制文件的内容 280
15.2.2 更新控制文件的内容 280
15.2.3 使用init.ora多路复用控制文件 281
15.2.4 使用SPFILE多路复用控制文件 282
15.2.5 创建控制文件 282
15.3 日志简介 285
15.4 管理日志文件 286
15.4.1 新建日志文件组 286
15.4.2 添加日志文件到日志文件组 287
15.4.3 删除日志文件组和日志文件 287
15.4.4 查询日志文件组和日志文件 288
15.5 疑难解惑 289
15.6 经典习题 289
第16章 数据备份与还原 290
16.1 数据备份 290
16.1.1 冷备份 290
16.1.2 热备份 291
16.2 数据还原 292
16.3 表的导出和导入 293
16.3.1 用EXP工具导出数据 294
16.3.2 用EXPDP导出数据 294
16.3.3 用IMP导入数据 295
16.3.4 用IMPDP导入数据 296
16.4 疑难解惑 296
16.5 经典习题 297
第17章 性能优化 298
17.1 优化简介 298
17.1.1 修改系统全局区 298
17.1.2 修改进程全局区 300
17.2 优化查询 301
17.2.1 分析查询语句的执行计划 301
17.2.2 索引对查询速度的影响 304
17.2.3 使用索引查询 304
17.2.4 优化子查询 305
17.3 优化数据库结构 305
17.3.1 将字段很多的表分解成多个表 305
17.3.2 增加中间表 307
17.3.3 增加冗余字段 308
17.3.4 优化插入记录的速度 309
17.4 优化Oracle服务器 310
17.4.1 优化服务器硬件 310
17.4.2 优化Oracle的参数 311
17.5 疑难解惑 313
17.6 经典习题 313
第18章 设计新闻发布系统数据库 314
18.1 系统概述 314
18.2 系统功能 315
18.3 数据库设计和实现 316
18.3.1 设计表 316
18.3.2 设计索引 321
18.3.3 设计视图 322
18.3.4 设计触发器 322
18.4 小结 323
第19章 设计论坛管理系统数据库 324
19.1 系统概述 324
19.2 系统功能 325
19.3 数据库设计和实现 326
19.3.1 设计方案图表 326
19.3.2 设计表 328
19.3.3 设计索引 332
19.3.4 设计视图 333
19.3.5 设计触发器 333
19.4 小结 335