书籍详情
Oracle9i PL/SQL程序设计
作者:(美)Scott Urman著;陈维军,王蕾等译
出版社:机械工业出版社
出版时间:2002-04-01
ISBN:9787111099505
定价:¥59.00
购买这本书可以去
内容简介
Oracle是一种功能极其强大,并且非常灵活的关系数据库系统。就是因为这种强大的功能和灵活性,致使Oracle非常复杂。为了实现基于Oracle设计有用的应用程序,则有必要理解Oracle是如何操作存储在系统中的数据的。PL/SQL就是这样一种实现数据操作的重要工具,你不仅可以在Oracle内部使用它,而且可以在自己的应用程序中应用它。PL/SQL在许多环境下都是可用的,并且在不同环境下具有不同的优势。
作者简介
暂缺《Oracle9i PL/SQL程序设计》作者简介
目录
译者序
前言
第一部分 概述及开发环境
第1章 PL/SQL概述
1.1 为什么使用PL/SQL
1.1.1 PL/SQL和网络流量
1.1.2 标准
1.2 PL/SQL的功能特性
1.2.1 语句块结构
1.2.2 错误处理
1.2.3 变量和类型
1.2.4 条件语句
1.2.5 循环结构
1.2.6 游标
1.2.7 过程和函数
1.2.8 包
1.2.9 集合
1.3 本书使用的约定
1.3.1 PL/SQL和Oracle版本
1.3.2 Oracle文档
1.3.3 光盘内容
1.4 范例样表
1.5 小结
第2章 开发及运行环境
2.1 应用程序模型和PL/SQL
2.1.1 两层模型
2.1.2 三层模型
2.1.3 连接服务器
2.2 PL/SQL开发工具
2.2.1 SQL*Plus
2.2.2 Rapid SQL
2.2.3 DBPartner Debugger
2.2.4 SQL Navigator
2.2.5 TOAD
2.2.6 SQL-programmer
2.2.7 PL/SQL Developer
2.2.8 开发工具小结
2.3 小结
第二部分 PL/SQL基本特性
第3章 PL/SQL基础
3.1 PL/SQL语句块
3.2 词法单元
3.2.1 标识符
3.2.2 分界符
3.2.3 文字
3.2.4 注释
3.3 变量声明
3.3.1 声明语法
3.3.2 变量初始化
3.4 PL/SQL类型
3.4.1 标量类型
3.4.2 复合类型
3.4.3 引用类型
3.4.4 LOB类型
3.4.5 对象类型
3.4.6 使用%TYPE
3.4.7 用户定义子类型
3.4.8 数据类型之间的转换
3.4.9 变量作用域和可见性
3.5 表达式和运算符
3.5.1 赋值
3.5.2 表达式
3.6 PL/SQL控制结构
3.6.1 IF-THEN-ELSE
3.6.2 CASE
3.6.3 循环
3.6.4 GOTO和标号
3.6.5 编译指示
3.7 PL/SQL记录
3.7.1 记录赋值
3.7.2 使用%ROWTYPE
3.8 PL/SQL风格指南
3.8.1 注释风格
3.8.2 变量名风格
3.8.3 大写风格
3.8.4 缩进风格
3.8.5 常见风格
3.9 小结
第4章 PL/SQL中的SQL
4.1 SQL语句
4.1.1 在PL/SQL中使用SQL
4.1.2 使用动态SQL
4.2 在PL/SQL中使用DML
4.2.1 SELECT
4.2.2 INSERT
4.2.3 UPDATE
4.2.4 DELETE
4.2.5 WHERE子句
4.2.6 批绑定
4.2.7 RETURNING子句
4.2.8 表引用
4.2.9 数据库链接
4.2.10 同义词
4.3 伪列
4.3.1 CURRVAL和NEXTVAL
4.3.2 LEVEL
4.3.3 ROWID
4.3.4 ROWNUM
4.4 GRANT、REVOKE和权限
4.4.1 对象和系统权限
4.4.2 GRANT和REVOKE
4.4.3 角色
4.5 事务控制
4.5.1 COMMIT和ROLLBACK
4.5.2 保存点
4.5.3 事务和语句块
4.5.4 自治事务
4.6 小结
第5章 内置SQL函数
5.1 概述
5.2 返回字符值的字符函数
5.2.1 SUBSTR、SUBSTRB、SUBSTRC、SUBSTR2和SUBSTR4
5.2.2 SOUNDEX
5.3 返回数字值的字符函数
5.3.1 INSTR、INSTRB、INSTRC、INSTR2和INSTR4
5.3.2 LENGTH、LENGTHB、LENGTHC、LENGTH2和LENGTH4
5.4 NLS函数
5.5 数字函数
5.6 日期和时间函数
5.7 转换函数
5.7.1 TO_CHAR(日期和日期时间)
5.7.2 TO_CHAR(数字)
5.7.3 TO_DATE
5.7.4 TO_NUMBER
5.7.5 TO_TIMESTAMP和TO_TIMESTAMP_TZ
5.8 聚集和分析函数
5.9 其他函数
5.9.1 DUMP
5.9.2 USERENV
5.10 小结
第6章 游标
6.1 什么是游标
6.1.1 处理显式游标
6.1.2 处理隐式游标
6.2 游标检索循环
6.2.1 简单循环
6.2.2 WHILE循环
6.2.3 游标FOR循环
6.2.4 NO_DATA_FOUND与%NOFTOUND
6.2.5 SELECT FOR UPDATE游标
6.3 游标变量
6.3.1 声明游标变量
6.3.2 为游标变量分配存储空间
6.3.3 为查询打开游标变量
6.3.4 关闭游标变量
6.3.5 游标变量范例一
6.3.6 游标变量范例二
6.3.7 使用游标变量的限制
6.4 小结
第7章 错误处理
7.1 什么是异常
7.1.1 声明异常
7.1.2 抛出异常
7.1.3 处理异常
7.1.4 EXCEPTION_INIT编译指示
7.1.5 使用RAISE_APPLICATION_ERROR
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 小结
第8章 集合
8.1 声明和使用集合类型
8.1.1 index-by表
8.1.2 嵌套表
8.1.3 可变数组
8.1.4 多层集合
8.1.5 集合类型之间的比较
8.2 数据库中的集合
8.2.1 存储集合的隐含式
8.2.2 操作整个集合
8.2.3 操作单个集合元素
8.3 集合方法
8.3.1 EXISTS
8.3.2 COUNT
8.3.3 LIMIT
8.3.4 FIRST和LAST
8.3.5 NEXT和PRIOR
8.3.6 EXTEND
8.3.7 TRIM
8.3.8 DELETE
8.4 小结
第三部分 更多PL/SQL特性
第9章 创建过程、函数和包
9.1 过程与函数
9.1.1 创建子程序
9.1.2 子程序参数
9.1.3 CALL语句
9.1.4 过程与函数
9.2 包
9.2.1 包的说明
9.2.2 包体
9.2.3 包和范围
9.2.4 重载封装子程序
9.2.5 包的初始化
9.3 小结
第10章 使用过程、函数和包
10.1 子程序位置
10.1.1 存储子程序和数据字典
10.1.2 局部子程序
10.1.3 存储子程序与局部子程序
10.2 存储子程序和包的考虑事项
10.2.1 子程序依赖性
10.2.2 包运行时状态
10.2.3 特权和存储子程序
10.3 在SQL语句中使用存储函数
10.3.1 纯度等级
10.3.2 缺省参数
10.3.3 在Oracle8i中从SQL调用存储函数
10.4 在共享池中的锁定
10.4.1 KEEP
10.4.2 UNKEEP
10.4.3 SIZES
10.4.4 ABORTED_REQUEST_THRESHOLD
10.5 小结
第11章 数据库触发器
11.1 触发器的类型
11.2 创建触发器
11.2.1 创建DML触发器
11.2.2 创建Instead-Of触发器
11.2.3 创建系统触发器
11.2.4 其他触发器问题
11.2.5 触发器和数据字典
11.3 变异表
11.3.1 变异表的例子
11.3.2 变异表错误的解决
11.4 小结
第12章 高级特性
12.1 语言特性
12.1.1 外部例程
12.1.2 本地动态SQL
12.1.3 成批绑定
12.1.4 对象类型
12.1.5 大对象
12.1.6 管道化表函数
12.2 高级包
12.2.1 DBMS_SQL
12.2.2 DBMS_PIPE
12.2.3 DBMS_ALERT
12.2.4 UTL_FILE
12.2.5 UTL_TCP
12.2.6 UTL_SMTP
12.2.7 UTL_HTTP
12.2.8 UTL_INADDR
12.2.9 DBMS_JOB
12.2.10 DBMS_LOB
12.3 小结
附录
附录A 包指南
附录B PL/SQL保留字
附录C 数据字典
前言
第一部分 概述及开发环境
第1章 PL/SQL概述
1.1 为什么使用PL/SQL
1.1.1 PL/SQL和网络流量
1.1.2 标准
1.2 PL/SQL的功能特性
1.2.1 语句块结构
1.2.2 错误处理
1.2.3 变量和类型
1.2.4 条件语句
1.2.5 循环结构
1.2.6 游标
1.2.7 过程和函数
1.2.8 包
1.2.9 集合
1.3 本书使用的约定
1.3.1 PL/SQL和Oracle版本
1.3.2 Oracle文档
1.3.3 光盘内容
1.4 范例样表
1.5 小结
第2章 开发及运行环境
2.1 应用程序模型和PL/SQL
2.1.1 两层模型
2.1.2 三层模型
2.1.3 连接服务器
2.2 PL/SQL开发工具
2.2.1 SQL*Plus
2.2.2 Rapid SQL
2.2.3 DBPartner Debugger
2.2.4 SQL Navigator
2.2.5 TOAD
2.2.6 SQL-programmer
2.2.7 PL/SQL Developer
2.2.8 开发工具小结
2.3 小结
第二部分 PL/SQL基本特性
第3章 PL/SQL基础
3.1 PL/SQL语句块
3.2 词法单元
3.2.1 标识符
3.2.2 分界符
3.2.3 文字
3.2.4 注释
3.3 变量声明
3.3.1 声明语法
3.3.2 变量初始化
3.4 PL/SQL类型
3.4.1 标量类型
3.4.2 复合类型
3.4.3 引用类型
3.4.4 LOB类型
3.4.5 对象类型
3.4.6 使用%TYPE
3.4.7 用户定义子类型
3.4.8 数据类型之间的转换
3.4.9 变量作用域和可见性
3.5 表达式和运算符
3.5.1 赋值
3.5.2 表达式
3.6 PL/SQL控制结构
3.6.1 IF-THEN-ELSE
3.6.2 CASE
3.6.3 循环
3.6.4 GOTO和标号
3.6.5 编译指示
3.7 PL/SQL记录
3.7.1 记录赋值
3.7.2 使用%ROWTYPE
3.8 PL/SQL风格指南
3.8.1 注释风格
3.8.2 变量名风格
3.8.3 大写风格
3.8.4 缩进风格
3.8.5 常见风格
3.9 小结
第4章 PL/SQL中的SQL
4.1 SQL语句
4.1.1 在PL/SQL中使用SQL
4.1.2 使用动态SQL
4.2 在PL/SQL中使用DML
4.2.1 SELECT
4.2.2 INSERT
4.2.3 UPDATE
4.2.4 DELETE
4.2.5 WHERE子句
4.2.6 批绑定
4.2.7 RETURNING子句
4.2.8 表引用
4.2.9 数据库链接
4.2.10 同义词
4.3 伪列
4.3.1 CURRVAL和NEXTVAL
4.3.2 LEVEL
4.3.3 ROWID
4.3.4 ROWNUM
4.4 GRANT、REVOKE和权限
4.4.1 对象和系统权限
4.4.2 GRANT和REVOKE
4.4.3 角色
4.5 事务控制
4.5.1 COMMIT和ROLLBACK
4.5.2 保存点
4.5.3 事务和语句块
4.5.4 自治事务
4.6 小结
第5章 内置SQL函数
5.1 概述
5.2 返回字符值的字符函数
5.2.1 SUBSTR、SUBSTRB、SUBSTRC、SUBSTR2和SUBSTR4
5.2.2 SOUNDEX
5.3 返回数字值的字符函数
5.3.1 INSTR、INSTRB、INSTRC、INSTR2和INSTR4
5.3.2 LENGTH、LENGTHB、LENGTHC、LENGTH2和LENGTH4
5.4 NLS函数
5.5 数字函数
5.6 日期和时间函数
5.7 转换函数
5.7.1 TO_CHAR(日期和日期时间)
5.7.2 TO_CHAR(数字)
5.7.3 TO_DATE
5.7.4 TO_NUMBER
5.7.5 TO_TIMESTAMP和TO_TIMESTAMP_TZ
5.8 聚集和分析函数
5.9 其他函数
5.9.1 DUMP
5.9.2 USERENV
5.10 小结
第6章 游标
6.1 什么是游标
6.1.1 处理显式游标
6.1.2 处理隐式游标
6.2 游标检索循环
6.2.1 简单循环
6.2.2 WHILE循环
6.2.3 游标FOR循环
6.2.4 NO_DATA_FOUND与%NOFTOUND
6.2.5 SELECT FOR UPDATE游标
6.3 游标变量
6.3.1 声明游标变量
6.3.2 为游标变量分配存储空间
6.3.3 为查询打开游标变量
6.3.4 关闭游标变量
6.3.5 游标变量范例一
6.3.6 游标变量范例二
6.3.7 使用游标变量的限制
6.4 小结
第7章 错误处理
7.1 什么是异常
7.1.1 声明异常
7.1.2 抛出异常
7.1.3 处理异常
7.1.4 EXCEPTION_INIT编译指示
7.1.5 使用RAISE_APPLICATION_ERROR
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 小结
第8章 集合
8.1 声明和使用集合类型
8.1.1 index-by表
8.1.2 嵌套表
8.1.3 可变数组
8.1.4 多层集合
8.1.5 集合类型之间的比较
8.2 数据库中的集合
8.2.1 存储集合的隐含式
8.2.2 操作整个集合
8.2.3 操作单个集合元素
8.3 集合方法
8.3.1 EXISTS
8.3.2 COUNT
8.3.3 LIMIT
8.3.4 FIRST和LAST
8.3.5 NEXT和PRIOR
8.3.6 EXTEND
8.3.7 TRIM
8.3.8 DELETE
8.4 小结
第三部分 更多PL/SQL特性
第9章 创建过程、函数和包
9.1 过程与函数
9.1.1 创建子程序
9.1.2 子程序参数
9.1.3 CALL语句
9.1.4 过程与函数
9.2 包
9.2.1 包的说明
9.2.2 包体
9.2.3 包和范围
9.2.4 重载封装子程序
9.2.5 包的初始化
9.3 小结
第10章 使用过程、函数和包
10.1 子程序位置
10.1.1 存储子程序和数据字典
10.1.2 局部子程序
10.1.3 存储子程序与局部子程序
10.2 存储子程序和包的考虑事项
10.2.1 子程序依赖性
10.2.2 包运行时状态
10.2.3 特权和存储子程序
10.3 在SQL语句中使用存储函数
10.3.1 纯度等级
10.3.2 缺省参数
10.3.3 在Oracle8i中从SQL调用存储函数
10.4 在共享池中的锁定
10.4.1 KEEP
10.4.2 UNKEEP
10.4.3 SIZES
10.4.4 ABORTED_REQUEST_THRESHOLD
10.5 小结
第11章 数据库触发器
11.1 触发器的类型
11.2 创建触发器
11.2.1 创建DML触发器
11.2.2 创建Instead-Of触发器
11.2.3 创建系统触发器
11.2.4 其他触发器问题
11.2.5 触发器和数据字典
11.3 变异表
11.3.1 变异表的例子
11.3.2 变异表错误的解决
11.4 小结
第12章 高级特性
12.1 语言特性
12.1.1 外部例程
12.1.2 本地动态SQL
12.1.3 成批绑定
12.1.4 对象类型
12.1.5 大对象
12.1.6 管道化表函数
12.2 高级包
12.2.1 DBMS_SQL
12.2.2 DBMS_PIPE
12.2.3 DBMS_ALERT
12.2.4 UTL_FILE
12.2.5 UTL_TCP
12.2.6 UTL_SMTP
12.2.7 UTL_HTTP
12.2.8 UTL_INADDR
12.2.9 DBMS_JOB
12.2.10 DBMS_LOB
12.3 小结
附录
附录A 包指南
附录B PL/SQL保留字
附录C 数据字典
猜您喜欢