书籍详情
轻松掌握:SQL
作者:(美)[R.K.斯蒂芬斯]Ryan K.Stephens,(美)[R.R.普莱夫]Ronald R.Plew著;郑利强[等]译;郑利强译
出版社:电子工业出版社
出版时间:2000-01-01
ISBN:9787505359130
定价:¥60.00
购买这本书可以去
内容简介
本书从基本概念、数据操作、系统管理和流行产品等4个方面,系统地介绍了结构化查询语言SQL的各个主要组成部分,较本书的第2版增加了更多的新主题。书中大量的实例和练习有助于读者理解和掌握SQL语言,提高在实际商业环境中应用和开发关系数据库的能力。本书适用于那些想迅速学会SQL语言的读者,同时对数据库开发人员具有较高的参考价值。
作者简介
暂缺《轻松掌握:SQL》作者简介
目录
第一篇
本篇概要
第1章 开始学习SQL语言
1.1 SQL语言历史简介
1.2 数据库历史简介
1.2.1 Codd博士关于数据库模型的12条准则
1.3 数据库结构设计
1.3.1 当今的数据库概述
1.4 跨产品语言
1.4.1 早期的实现
1.4.2 SQL和客户/服务器应用的开发
1.5 SQL语言概述
1.6 几种较流行的 SQL语言的实现
1.6.1 Microsoft Access_
1.6.2 Personal Oracle8
l.6.3 Microsoft Query
l.7 开放数据库连接(ODBC)
1.8 应用程序编程中的SQL语言
1.9 小结
1.10 问与答
1.11 工作室
1.11.1 测验
1.11.2 练习
第2章 查询简介
2.1 SQL语言的背景
2.2 一般的句法格式
2.3 用SELECT及FROM建立数据检索块
2.4 示例
2.5 第一个查询
2.5.1 结束一个SQL语句
2.5.2 改变列的顺序
2.5.3 选择特定的列
2.5.4 从不同表中选择数据
2.6 使用区别(Distinction)查询
2.7 小结
2.8 问与答
2.9 工作室
2.9. 测验
2.9.2 练习
第3章 表达式、条件和操作符
3.1 表达式
3.2 条件
3.2.1 WHERE子句
3.3 操作符
3.3.1 算术操作符
3.3.2 比较操作符
3.3.3 字符操作符
3.3.4 逻辑操作符
3.3.5 集合操作符
3.3.6 其它操作符:IN和BETWEEN
3.4 小结
3.5 问与答
3.6 工作室
3.6.1 测验
3.6.2 练习
第4章 利用内置函数生成数据
4.1 聚集函数
4.1.1 COUNT函数
4.1.2 SUM函数
4.1.3 AVG函数
4.1.4 MAX函数
4.1.5 MIN函数
4.1.6 VARIANCE函数
4.1.7 STDDEV函数
4.2 日期和时间函数
4.2.1 ADD_MONTHS函数
4.2.2 LAST_DAY函数
4.2.3 MONTHS_BETWEEN函数
4.2.4 NEW_TIME函数
4.2.5 NEXT_DAY函数
4.2.6 SYSDATE函数
4.3 算术函数
4.3.1 ABS函数
4.3.2 CEIL和FLOOR函数
4.3.3 COS、COSH、SIN、SINH、TAN、TANH函数
4.3.4 EXP函数
4.3.5 SLN和LOG函数
4.3.6 MOD函数
4.3.7 POWER函数
4.3.8 SIGN函数
4.3.9 SQRT函数
4.4 字符函数
4.4.1 CHR函数
4.4.2 CONCAT函数
4.4.3 INITCAP函数
4.4.4 LOWER和UPPER函数
4.4.5 LPAD和RPAD函数
4.4.6 LTRIM和RTRIM函数
4.4.7 REPLACE函数
4.4.8 SUBSTR函数
4.4.9 TRANSLATE函数
4.4.10 INSTR函数
4.4.11 LENGTH函数
4.5 转换函数
4.5.1 TO_CHAR函数
4.5.2 TO_NUMBER函数
4.6 其他函数
4.6.1 GREATEST和LEAST函数
4.6.2 USER函数
4.7 小结
4.8 问与答
4.9 工作室
4.9.1 测验
4.9.2 练习
第5章 SQL查询中的子句
5.1 用WHERE子句指定查询条件
5.2 STARTING WITH子句
5.3 ORDER BY子句——把混乱变为有序
5.4 GROUP BY子句
5.5 HAVING子句
5.6 复合子句
5.6.1 大结局
5.7 小结
5.8 问与答
5.9 工作室
5.9.1 测验
5.9.2 练习
第6章 连接表
6.1 在单个SELECT语句中的多重表
6.1.1 交叉连接表
6.1.2 寻找正确的列
6.2 相等连接
6.3 不等连接
6.4 外部连接和内部连接
6.5 将表与自己连接:自连接
6.6 小结
6.7 问与答
6.8 工作室、
6.8.1 测验
6.8.2 练习
第7章 子查询:嵌入式SELECT语句
7.1 建立一个子查询
7.2 在子查询中使用聚集函数
7.3 嵌套子查询
7.4 参照外部表的相关子查询
7.5 使用EXISTS、ANY和ALL
7.6 小结
7.7 问与答
7.8 工作室
7.8.1 测验
7.8.2 练习
第一篇回顾
第二篇
本篇概要
第8章 数据库规范化
8.1 规范化数据库
8.1.1 原始数据库
8.1.2 数据库逻辑设计
8.2 范式
8.2.1 第一范式
8.2.2 第二范式
8.2.3 第三范式
8.3 数据库规范化操作
8.3.1 参照完整性
8.3.2 数据库规范化的优点
8.3.3 数据库规范化的缺点
8.3.4 将数据库非规范化
8.4 小结
8.5 问与答
8.6 工作室
8.6.1 测验
8.6.2 练习
第9章 创建和维护表
9.1 CREATE DATABASE语句
9.1.1 CREATE DATABASE选项
9.1.2 数据库设计
9.1.3 创建数据字典
9.1.4 创建关键字段
9.2 CREATE TABLE语句
9.2.1 表名
9.2.2 字段名
9.2.3 字段的数据类型
9.2.4 表的存储和尺寸
9.2.5 由一个现存的表创建表
9.3 ALTER TABLE语句
9.4 DROP TABLE语句
9.5 OROP DATABASE语句
9.6 小结
9.7 问与答
9.8 工作室
9.8.1 测验
9.8.2 练习
第10章 数据完塑性控制
10.1 约束简介
10.1.1 数据完整性
10.1.2 为什么使用约束
10.2 约束的种类
10.2.1 非空约束(NOT NULL)
10.2.2 主键约束
10.2.3 唯一约束
10.2.4 外键约束
10.2.5 检验约束
10.3 约束管理
10.3.1 约束的正确次序
10.3.2 创建约束的正确方法
10.3.3 Oracle参照完整性报告实例
10.4 小结
10.5 问与答
10.6 工作室
10.6.1 测验
10.6.2 练习
第11章 操作数据
11.1 数据操作语句简介
11.2 用INSERT语句输入数据
11.2.1 用INSERT...VALUES语句输入一条记录
11.2.2 插入NULL值(空值)
11.2.3 插入唯一值
11.2.4 用INSERT SELECT语句输入多条记录
11.3 用UPDATE语句更新现有数据
11.4 用DELETE语句删除信息
11.5 从外部数据源输入和输出数据
11.5.1 Microsoft Access
11.5.2 Microsoft SQL Server
11.5.3 Personal Oracle8
11.6 小结
11.7 问与答
11.8 工作室
11.8.1 测验
11.8.2 练习
第12章 事务控制
12.1 事务控制
12.1.1 银行应用
12.2 开始一个事务
12.3 结束一个事务
12.4 撤销事务
12.5 使用事务保存点(SAVEPOINT)
12.6 小结
12.7 问与答
12.8 工作室
12.8.1 测验
12.8.2 练习
第13章 SQL语言中的日期与时间
13.1 如何存储日期与时间型数据
13.1.1 ANSI标准的日期与时间型数据
13.1.2 DATETIME元素
13.1.3 特定数据类型的实现
13.2 日期函数
13.2.1 当前日期
13.2.2时区
13.2.3 在日期上增加时间
13.2.4 日期相减
13.2.5 比较日期和时间段
13.2.6 其他的日期函数
13.3 日期转换
13.3.1 日期描述
133.2 转换日期为字符串
13.3.3 转换字符串为日期
13.4 小结
13.5 问与答
13.6 工作室
13.6.1 测验
13.6.2 练习
第14章 创建视图
14.1 视图简介
14.2 使用视图
14.2.1 考察简单视图
14.2.2 更改列名
14.2.3 查看SQL视图处理过程
14.2.4 使用 SELECT语句的限制
14 2.5 在视图中修改数据
14.2.6 与使用视图修改数据有关的问题
14.2.7 视图的一般应用
14.2.8 用DROP VIEW语句删除视图
14.3 小结
14.4 问与答
14.5 工作室
14.5.1 测验
14.5.2 练习
第二篇 回顾
第三篇
本篇概要
第15章 在表上创建索引以提高数据库性能
15.1 使用索引
15.1.1 索引是什么
15.1.2 索引技巧
15.1.3 在多个字段上建立索引
15.1.4 使用带有UNIQUE关键字的CREATE INDEX语句
15.1.5 索引与连接
15.1.6 使用聚簇(Cluster)
15.2 小结
15.3 问与答
15.4 工作室
15.4.1 测验
15.4.2 练习
第16章 优化SQL语句以提高性能
16.1 提高SQL语句的可读性
16.2 避免扫描整个表
16.3 增加一个新索引
16.4 查询中各成分的安排
16.4.1 过程
16.4.2 避免使用 OR
16.5 联机分析处理(OLAP)与联机事务处理(OLTP)
16.5.1 OLTP调整
16.5.2 OLAP调整
16.6 成批装入与事务处理
16.7 通过删除索引优化数据装载
16.8 经常提交数据——保证系统系统运行的关键
16.9 在动态环境中重建表和索引
16.10 调整数据库
16.11 影响数据库性能的因素
16.12 内置调整工具
16.13 小结
16.14 问与答
16.15 工作室
16.15.1期 测验
16.15.2 练习
第17章 数据库安全性
17.1 数据库管理员须知
17.2 流行的数据库产品及其安全性
17.3 如何确保数据库的安全性
174 Personal Oracle8和安全性
17.4.1 创建用户
17.4.2 创建角色(Role)
17.4.3 用户特权
17.4.4 用户访问视图
17.4.5 用视图实现安全性
17.4.6 使用同义词代替视图
17.4.7 使用 WITH GRANT OPTION子句
17.5 小结
17.6 问与答
17.7 工作室
17.7.1 测验
17.7.2 练习
第18章 数据字典
18.1 数据字典介绍
18.2 数据字典的用户
18.3 数据字典的内容
18.3.1 Oracle的数据字典
18.3.2 Sybase的数据字典
18.4 Oracle数据字典的剖析
18.4.1 用户视图
18.4.2 系统DBA视图
18.4.3 动态性能视图
18.4.4 PLAN表
18.5 小结
18.6 问与答
18.7 工作室
18.7.1 测验
18.7.2 练习
第19章 存储过程、触发器和嵌入式以及语言
19.1 创建临时表
19.2 使用游标
19.2.1 创建游标
19.2.2 打开游标
19.2.3 滚动游标
19.2.4 测试游标的状态
19.2.5 关闭游标
19.2.6 游标的使用域
19.3 创建并使用存储过程
19.3.1 使用存储过程参数
19.3.2 删除存储过程
19.3.3 嵌套存储过程
19.4 设计和使用触发器
19.4.1 触发器和事务
19.4.2 使用触发器的限制
19.4.3 嵌套触发器
19.5 在执行之前测试SELECT语句
19.6 使用嵌入式SQL语言
19.6.1 静态和动态 SQL语言
19.7 使用SQL编程
19.8 小结
19.9 问与答
19.10 工作室
19.10.1 测验
19.10.2 练习
第20章 SQL语言新标准——SQL中的新对象
20.1 CREATE ROLE语句探讨
20.2 创建触发器
20.3 使用CREATE TYPE语句
20.4 小结
20.5 问与答
20.6 工作室
20.6.1 测验
20.6.2 练习
第21章 使用SQL语言生成SQL语句
Z1.1 使用SQL语言生成SQL语句的目的
21.2 几个SQL*Plus命令
Z1.1.1 SET ECHO ON/OFF
21.2.2 SET FEEDBACK ON/OFF
21.2.3 SET HEADING ON/OFF
21.2.4 SPOOL FILENAME/OFF
21.2.5 START FILENAME
21.2.6 ED FILENAME
21.3 统计所有表中的行数
21.4 为多个用户授予系统权限
21.5 将表的权限授予其他用户
21.6 为装入数据而废除对表的约束
21.7 在单个区域内创建大量的同义词
21.8 在表上创建视图
21.9 截断某一用户的所有表
ZI.10 使用SQL语句生成Shell脚本
21.11 对表和索引进行逆向工程
21.12 小结
21.13 问与答
21.14 工作室
21.14.1 测验
21.14.2 练习
第三篇回顾
附加篇
本篇概要
第22章 SQL语句的调试
22.1 常见错误
22.1.1 表或视图不存在
22.1.2 无效的用户名或口令
22.1.3 没有FROM关键字
22.1.4 不允许使用分组函数
221.5 无效的列名
22.1.6 缺少关键字
22.1.7 缺少左括号
22.1.8 缺少右括号
22.1.9 缺少逗号
22.1.10 列名定义不明确
22.1.11 SQL命令没有正常结束
22.1.12 缺少表达式
22.1.13 函数缺少参数
22.1.14 缺少数据值
22.1.15 完整性约束冲突——双亲主键没有找到
22.1.16 Oracle不能使用
22.1.17 向列中插入的数据太大
22.1.18 远程数据库服务器不能识别连接描述符中的系统ID号
22.1.19 没有授权的权限
22.1.20 语句中的无效字符——Escape字符
22.1.21 对不能创建操作系统文件
22.2 常见的逻辑错误
22.2.1 在SQL语句中使用保留字
22.2.2 在多个选择列上使用DISTINCT命令
22.2.3 删除不合适的表
22.2.4 在多模式的数据库中公共同义词的使用
22.2.5 可怕的笛卡尔乘积
22.2.6 数据输入质量不高
22.2.7 采用不合适的文件系统结核
22.2.8 对于很大的表采用缺省的存储参数
22.2.9 将数据库对象存储到系统表空间中
22.2.10 大量的备份文件没有压缩
22.2.11 没有规划好系统资源的使用
22.3 防止数据出现麻烦
22.3.1 在数据库中查找重复的记录
22.4 小结
22.5 问与答
22.6 工作室
22.6.1 测验
22.6.2 练习
第23章 创建复合查询
23.1 本章使用的表
23.2 复合查询的例子
23.2.1 根据生日计算年龄
23.2.2 将一个DAY函数分解成小时、 分和秒
23.2.3 将字节转换成KB和MB
23.2.4 数据库中段的报表
23.2.5 DML中的子查询
23.2.6 格式化日期
23.2 7 包含取最大值的子查询
23.2.8 多个子查询
23.2.9 使用破折号和括号格式化数值型数据
23.2.10 将数值型数据按给定的比递增
23.2.11 在一个列中查找下一个最大的数值
23.2.12 空值(NULL)处理
23.3 建立复合查询的技巧
23.4 小结
23.5 问与答
23.6 工作室
23.6.1 测验
23.6.2 练习
第24章 用Oracle的SQL*Plus生成满意的报表
24.1 SQL*Plus介绍
24.2 SQL*plus缓冲区
24.3 用DESCRIBE命令查看表结构
24.4 用SHOW命令显示系统设置
24.5 用文件命令操作文件
24.5.1 SAVE、GET和 EDIT命令
24.5.2 运行SQL文件
24.5.3 存储查询结果
24.6 用SET命令设置工作环境
24.7 使用LOGIN.SQL文件
24.8 用CLEAR命令清除SQL*Plus的设置
24.9 格式化输出结果
24.9.1 TTITLE和 BTITLE
24.9.2 格式化的列(列、标题、格式)
24. 10 创建报表和分组合计
24.10.1 BREAK ON
24.10.2 COMPUTE
24.11 SQL*Plus中使用变量
24.11.1 替代变量(&)
24.11.2 DEFINE
24.11.3 ACCEPT
24.11.4 NEW VALUE
24. 12 使用DUAL表
24.13 DECODE函数
24.14 日期转换
24.15 执行一系列SQL文件
24.16 在SQL脚本文件中加注释
24. 17 高级报表
24.18 小结
24. 19 问与答
24.20 工作室
24.20.1 测验
24.20.2 练习
第25章 Oracle的PL/SQL语言简介
25.1 PL/SQL介绍
25.2 PL/SQ L中的数据类型
25.2.1 字符串数据类型
25.2.2 数值数据类型
25.2.3 二进制数据类型
25.2.4 日期数据类型
25.2.5 布尔型
25.2.6 行号(ROWID)
25.3 PL/SQL程序块结构
25.4 DECLAREd部分
25.4.1 变量赋值
25.4.2 常量赋值
25.4.3 游标的定义
25.4.4 %TYPE属性
25.4.5 % ROWTYPE属性
25.4.6 %ROWCOUNT属性
25.5 PROCEDURE部分
25.5.1 BEGIN...END语句
25.5.2 游标控制命令
25.5.3 条件语句
25.6 EXCEPTION部分
25.6.1 异常事件的触发
25.6.2 异常事件处理程序的执行
25.6.3 插入注解
25.6.4 PL/SQL程序块的执行
25.6.5 为用户显示输出结果
25.7 PL/SQL中的事务控制
25.8 PL/SQL程序的完整介绍
25.8.1 样表和数据
25.8.2 PL/SQL程序块实例
25.8.3 另一个实例
25.9 存储过程、程序包和触发器
25.9.1 存储过程样本
25.9.2 程序包样本
25.9.3 触发器样本
25.10 小结
25.11 问与答
25.12.1 工作室
25.12.1 测验
25.12.2 练习
第26章 Transact SQL介绍
26.1 Transact-SQL概述
26.2 对ANSI SQL语言的扩充
26.2.1 Transact-SQL面向哪些用户
26.2.2 Transact-SQL的基本构成
26.3 数据类型
26.3.1 字符串类型
26.3.2 数值数据类型
26.3.3 日期数据类型
26.3.4 货币数据类型
26.3.5 二进制串
26.3.6 位(bit)——一种逻辑数据类型
26.4 使用 Transact-SQL访问数据库
26.4.1 BASEBALL数据库
26.4.2 局部变量的声明
26.4.3 全局变量的声明
26.4.4 变量的使用
26.4.5 PRINT命令
26.5 建立程序流程控制
26.5.1 BEGIN和END语句
26.5.2 IF...ELSE语句
26.5.3 EXISTS条件
26.5.4 测试查询结果
26.5.5 WHILE循环
26.5.6 BREAK命令
26.5.7 CONTINUE命令
26.5.8 使用WHILE循环滚动访问一个表
26.6 Transact-SQL通配符
26.7 使用COMPUTE命令创建合计报表
26.8 日期转换
26.9 SQL Server的诊断工具——SET命令
26.10 小结
26.11 问与答
26.12 工作室
26.12.1 测验
26.12.2 练习
第27章 Visual C++和Delphi中的动态SQL语言
27.1 几个应用程序开发工具简介
27.1.1 ODBC
27.1.2 Personal Oracle8
27.1.3 InterBase SQL
27.1.4 VisualC++
27.1.5 Delphi
27.2 开始运行Oracle和InterBase
27.3 创建数据库
27.4 用Microsoft Query执行连接
27.5 使用 VisualC++和SQL
27.6 使用 Delphi和SQL
27.7 小结
27.8 问与答
27.9 工作室
27.9.1 测验
27.9.2 练习
第28章 MySQL介绍
28.1 MySQL管理
28.1.1 MySQL安装
28.1.2 启动和停止MySQL
28.1.3 MySQL的初始
28.2 MySQL客户端程序
28.2.1 连接数据库
28.2.2 命令行选项
28.2.3 输入MySQL客
28.2.4 执行命令的历史记录
28.2.5 批处理模式
28.2.6 SHOW命令
28.3 MySQL实用程序
28.4 小结
28.5 问与答
28.6 工作室
28.7.1 测验
28.8.2 练习
附加篇回顾
附录
附录A 答案
附录B 创建表的实例代码
附录C 生成Plpulate表中数据的代码
附录D 第27章的C++程序源代码
附录E 第27章的Delphi程序源代码
附录F 常用SQL命令术语
附录G ASCll码表
附录H 相关资源
本篇概要
第1章 开始学习SQL语言
1.1 SQL语言历史简介
1.2 数据库历史简介
1.2.1 Codd博士关于数据库模型的12条准则
1.3 数据库结构设计
1.3.1 当今的数据库概述
1.4 跨产品语言
1.4.1 早期的实现
1.4.2 SQL和客户/服务器应用的开发
1.5 SQL语言概述
1.6 几种较流行的 SQL语言的实现
1.6.1 Microsoft Access_
1.6.2 Personal Oracle8
l.6.3 Microsoft Query
l.7 开放数据库连接(ODBC)
1.8 应用程序编程中的SQL语言
1.9 小结
1.10 问与答
1.11 工作室
1.11.1 测验
1.11.2 练习
第2章 查询简介
2.1 SQL语言的背景
2.2 一般的句法格式
2.3 用SELECT及FROM建立数据检索块
2.4 示例
2.5 第一个查询
2.5.1 结束一个SQL语句
2.5.2 改变列的顺序
2.5.3 选择特定的列
2.5.4 从不同表中选择数据
2.6 使用区别(Distinction)查询
2.7 小结
2.8 问与答
2.9 工作室
2.9. 测验
2.9.2 练习
第3章 表达式、条件和操作符
3.1 表达式
3.2 条件
3.2.1 WHERE子句
3.3 操作符
3.3.1 算术操作符
3.3.2 比较操作符
3.3.3 字符操作符
3.3.4 逻辑操作符
3.3.5 集合操作符
3.3.6 其它操作符:IN和BETWEEN
3.4 小结
3.5 问与答
3.6 工作室
3.6.1 测验
3.6.2 练习
第4章 利用内置函数生成数据
4.1 聚集函数
4.1.1 COUNT函数
4.1.2 SUM函数
4.1.3 AVG函数
4.1.4 MAX函数
4.1.5 MIN函数
4.1.6 VARIANCE函数
4.1.7 STDDEV函数
4.2 日期和时间函数
4.2.1 ADD_MONTHS函数
4.2.2 LAST_DAY函数
4.2.3 MONTHS_BETWEEN函数
4.2.4 NEW_TIME函数
4.2.5 NEXT_DAY函数
4.2.6 SYSDATE函数
4.3 算术函数
4.3.1 ABS函数
4.3.2 CEIL和FLOOR函数
4.3.3 COS、COSH、SIN、SINH、TAN、TANH函数
4.3.4 EXP函数
4.3.5 SLN和LOG函数
4.3.6 MOD函数
4.3.7 POWER函数
4.3.8 SIGN函数
4.3.9 SQRT函数
4.4 字符函数
4.4.1 CHR函数
4.4.2 CONCAT函数
4.4.3 INITCAP函数
4.4.4 LOWER和UPPER函数
4.4.5 LPAD和RPAD函数
4.4.6 LTRIM和RTRIM函数
4.4.7 REPLACE函数
4.4.8 SUBSTR函数
4.4.9 TRANSLATE函数
4.4.10 INSTR函数
4.4.11 LENGTH函数
4.5 转换函数
4.5.1 TO_CHAR函数
4.5.2 TO_NUMBER函数
4.6 其他函数
4.6.1 GREATEST和LEAST函数
4.6.2 USER函数
4.7 小结
4.8 问与答
4.9 工作室
4.9.1 测验
4.9.2 练习
第5章 SQL查询中的子句
5.1 用WHERE子句指定查询条件
5.2 STARTING WITH子句
5.3 ORDER BY子句——把混乱变为有序
5.4 GROUP BY子句
5.5 HAVING子句
5.6 复合子句
5.6.1 大结局
5.7 小结
5.8 问与答
5.9 工作室
5.9.1 测验
5.9.2 练习
第6章 连接表
6.1 在单个SELECT语句中的多重表
6.1.1 交叉连接表
6.1.2 寻找正确的列
6.2 相等连接
6.3 不等连接
6.4 外部连接和内部连接
6.5 将表与自己连接:自连接
6.6 小结
6.7 问与答
6.8 工作室、
6.8.1 测验
6.8.2 练习
第7章 子查询:嵌入式SELECT语句
7.1 建立一个子查询
7.2 在子查询中使用聚集函数
7.3 嵌套子查询
7.4 参照外部表的相关子查询
7.5 使用EXISTS、ANY和ALL
7.6 小结
7.7 问与答
7.8 工作室
7.8.1 测验
7.8.2 练习
第一篇回顾
第二篇
本篇概要
第8章 数据库规范化
8.1 规范化数据库
8.1.1 原始数据库
8.1.2 数据库逻辑设计
8.2 范式
8.2.1 第一范式
8.2.2 第二范式
8.2.3 第三范式
8.3 数据库规范化操作
8.3.1 参照完整性
8.3.2 数据库规范化的优点
8.3.3 数据库规范化的缺点
8.3.4 将数据库非规范化
8.4 小结
8.5 问与答
8.6 工作室
8.6.1 测验
8.6.2 练习
第9章 创建和维护表
9.1 CREATE DATABASE语句
9.1.1 CREATE DATABASE选项
9.1.2 数据库设计
9.1.3 创建数据字典
9.1.4 创建关键字段
9.2 CREATE TABLE语句
9.2.1 表名
9.2.2 字段名
9.2.3 字段的数据类型
9.2.4 表的存储和尺寸
9.2.5 由一个现存的表创建表
9.3 ALTER TABLE语句
9.4 DROP TABLE语句
9.5 OROP DATABASE语句
9.6 小结
9.7 问与答
9.8 工作室
9.8.1 测验
9.8.2 练习
第10章 数据完塑性控制
10.1 约束简介
10.1.1 数据完整性
10.1.2 为什么使用约束
10.2 约束的种类
10.2.1 非空约束(NOT NULL)
10.2.2 主键约束
10.2.3 唯一约束
10.2.4 外键约束
10.2.5 检验约束
10.3 约束管理
10.3.1 约束的正确次序
10.3.2 创建约束的正确方法
10.3.3 Oracle参照完整性报告实例
10.4 小结
10.5 问与答
10.6 工作室
10.6.1 测验
10.6.2 练习
第11章 操作数据
11.1 数据操作语句简介
11.2 用INSERT语句输入数据
11.2.1 用INSERT...VALUES语句输入一条记录
11.2.2 插入NULL值(空值)
11.2.3 插入唯一值
11.2.4 用INSERT SELECT语句输入多条记录
11.3 用UPDATE语句更新现有数据
11.4 用DELETE语句删除信息
11.5 从外部数据源输入和输出数据
11.5.1 Microsoft Access
11.5.2 Microsoft SQL Server
11.5.3 Personal Oracle8
11.6 小结
11.7 问与答
11.8 工作室
11.8.1 测验
11.8.2 练习
第12章 事务控制
12.1 事务控制
12.1.1 银行应用
12.2 开始一个事务
12.3 结束一个事务
12.4 撤销事务
12.5 使用事务保存点(SAVEPOINT)
12.6 小结
12.7 问与答
12.8 工作室
12.8.1 测验
12.8.2 练习
第13章 SQL语言中的日期与时间
13.1 如何存储日期与时间型数据
13.1.1 ANSI标准的日期与时间型数据
13.1.2 DATETIME元素
13.1.3 特定数据类型的实现
13.2 日期函数
13.2.1 当前日期
13.2.2时区
13.2.3 在日期上增加时间
13.2.4 日期相减
13.2.5 比较日期和时间段
13.2.6 其他的日期函数
13.3 日期转换
13.3.1 日期描述
133.2 转换日期为字符串
13.3.3 转换字符串为日期
13.4 小结
13.5 问与答
13.6 工作室
13.6.1 测验
13.6.2 练习
第14章 创建视图
14.1 视图简介
14.2 使用视图
14.2.1 考察简单视图
14.2.2 更改列名
14.2.3 查看SQL视图处理过程
14.2.4 使用 SELECT语句的限制
14 2.5 在视图中修改数据
14.2.6 与使用视图修改数据有关的问题
14.2.7 视图的一般应用
14.2.8 用DROP VIEW语句删除视图
14.3 小结
14.4 问与答
14.5 工作室
14.5.1 测验
14.5.2 练习
第二篇 回顾
第三篇
本篇概要
第15章 在表上创建索引以提高数据库性能
15.1 使用索引
15.1.1 索引是什么
15.1.2 索引技巧
15.1.3 在多个字段上建立索引
15.1.4 使用带有UNIQUE关键字的CREATE INDEX语句
15.1.5 索引与连接
15.1.6 使用聚簇(Cluster)
15.2 小结
15.3 问与答
15.4 工作室
15.4.1 测验
15.4.2 练习
第16章 优化SQL语句以提高性能
16.1 提高SQL语句的可读性
16.2 避免扫描整个表
16.3 增加一个新索引
16.4 查询中各成分的安排
16.4.1 过程
16.4.2 避免使用 OR
16.5 联机分析处理(OLAP)与联机事务处理(OLTP)
16.5.1 OLTP调整
16.5.2 OLAP调整
16.6 成批装入与事务处理
16.7 通过删除索引优化数据装载
16.8 经常提交数据——保证系统系统运行的关键
16.9 在动态环境中重建表和索引
16.10 调整数据库
16.11 影响数据库性能的因素
16.12 内置调整工具
16.13 小结
16.14 问与答
16.15 工作室
16.15.1期 测验
16.15.2 练习
第17章 数据库安全性
17.1 数据库管理员须知
17.2 流行的数据库产品及其安全性
17.3 如何确保数据库的安全性
174 Personal Oracle8和安全性
17.4.1 创建用户
17.4.2 创建角色(Role)
17.4.3 用户特权
17.4.4 用户访问视图
17.4.5 用视图实现安全性
17.4.6 使用同义词代替视图
17.4.7 使用 WITH GRANT OPTION子句
17.5 小结
17.6 问与答
17.7 工作室
17.7.1 测验
17.7.2 练习
第18章 数据字典
18.1 数据字典介绍
18.2 数据字典的用户
18.3 数据字典的内容
18.3.1 Oracle的数据字典
18.3.2 Sybase的数据字典
18.4 Oracle数据字典的剖析
18.4.1 用户视图
18.4.2 系统DBA视图
18.4.3 动态性能视图
18.4.4 PLAN表
18.5 小结
18.6 问与答
18.7 工作室
18.7.1 测验
18.7.2 练习
第19章 存储过程、触发器和嵌入式以及语言
19.1 创建临时表
19.2 使用游标
19.2.1 创建游标
19.2.2 打开游标
19.2.3 滚动游标
19.2.4 测试游标的状态
19.2.5 关闭游标
19.2.6 游标的使用域
19.3 创建并使用存储过程
19.3.1 使用存储过程参数
19.3.2 删除存储过程
19.3.3 嵌套存储过程
19.4 设计和使用触发器
19.4.1 触发器和事务
19.4.2 使用触发器的限制
19.4.3 嵌套触发器
19.5 在执行之前测试SELECT语句
19.6 使用嵌入式SQL语言
19.6.1 静态和动态 SQL语言
19.7 使用SQL编程
19.8 小结
19.9 问与答
19.10 工作室
19.10.1 测验
19.10.2 练习
第20章 SQL语言新标准——SQL中的新对象
20.1 CREATE ROLE语句探讨
20.2 创建触发器
20.3 使用CREATE TYPE语句
20.4 小结
20.5 问与答
20.6 工作室
20.6.1 测验
20.6.2 练习
第21章 使用SQL语言生成SQL语句
Z1.1 使用SQL语言生成SQL语句的目的
21.2 几个SQL*Plus命令
Z1.1.1 SET ECHO ON/OFF
21.2.2 SET FEEDBACK ON/OFF
21.2.3 SET HEADING ON/OFF
21.2.4 SPOOL FILENAME/OFF
21.2.5 START FILENAME
21.2.6 ED FILENAME
21.3 统计所有表中的行数
21.4 为多个用户授予系统权限
21.5 将表的权限授予其他用户
21.6 为装入数据而废除对表的约束
21.7 在单个区域内创建大量的同义词
21.8 在表上创建视图
21.9 截断某一用户的所有表
ZI.10 使用SQL语句生成Shell脚本
21.11 对表和索引进行逆向工程
21.12 小结
21.13 问与答
21.14 工作室
21.14.1 测验
21.14.2 练习
第三篇回顾
附加篇
本篇概要
第22章 SQL语句的调试
22.1 常见错误
22.1.1 表或视图不存在
22.1.2 无效的用户名或口令
22.1.3 没有FROM关键字
22.1.4 不允许使用分组函数
221.5 无效的列名
22.1.6 缺少关键字
22.1.7 缺少左括号
22.1.8 缺少右括号
22.1.9 缺少逗号
22.1.10 列名定义不明确
22.1.11 SQL命令没有正常结束
22.1.12 缺少表达式
22.1.13 函数缺少参数
22.1.14 缺少数据值
22.1.15 完整性约束冲突——双亲主键没有找到
22.1.16 Oracle不能使用
22.1.17 向列中插入的数据太大
22.1.18 远程数据库服务器不能识别连接描述符中的系统ID号
22.1.19 没有授权的权限
22.1.20 语句中的无效字符——Escape字符
22.1.21 对不能创建操作系统文件
22.2 常见的逻辑错误
22.2.1 在SQL语句中使用保留字
22.2.2 在多个选择列上使用DISTINCT命令
22.2.3 删除不合适的表
22.2.4 在多模式的数据库中公共同义词的使用
22.2.5 可怕的笛卡尔乘积
22.2.6 数据输入质量不高
22.2.7 采用不合适的文件系统结核
22.2.8 对于很大的表采用缺省的存储参数
22.2.9 将数据库对象存储到系统表空间中
22.2.10 大量的备份文件没有压缩
22.2.11 没有规划好系统资源的使用
22.3 防止数据出现麻烦
22.3.1 在数据库中查找重复的记录
22.4 小结
22.5 问与答
22.6 工作室
22.6.1 测验
22.6.2 练习
第23章 创建复合查询
23.1 本章使用的表
23.2 复合查询的例子
23.2.1 根据生日计算年龄
23.2.2 将一个DAY函数分解成小时、 分和秒
23.2.3 将字节转换成KB和MB
23.2.4 数据库中段的报表
23.2.5 DML中的子查询
23.2.6 格式化日期
23.2 7 包含取最大值的子查询
23.2.8 多个子查询
23.2.9 使用破折号和括号格式化数值型数据
23.2.10 将数值型数据按给定的比递增
23.2.11 在一个列中查找下一个最大的数值
23.2.12 空值(NULL)处理
23.3 建立复合查询的技巧
23.4 小结
23.5 问与答
23.6 工作室
23.6.1 测验
23.6.2 练习
第24章 用Oracle的SQL*Plus生成满意的报表
24.1 SQL*Plus介绍
24.2 SQL*plus缓冲区
24.3 用DESCRIBE命令查看表结构
24.4 用SHOW命令显示系统设置
24.5 用文件命令操作文件
24.5.1 SAVE、GET和 EDIT命令
24.5.2 运行SQL文件
24.5.3 存储查询结果
24.6 用SET命令设置工作环境
24.7 使用LOGIN.SQL文件
24.8 用CLEAR命令清除SQL*Plus的设置
24.9 格式化输出结果
24.9.1 TTITLE和 BTITLE
24.9.2 格式化的列(列、标题、格式)
24. 10 创建报表和分组合计
24.10.1 BREAK ON
24.10.2 COMPUTE
24.11 SQL*Plus中使用变量
24.11.1 替代变量(&)
24.11.2 DEFINE
24.11.3 ACCEPT
24.11.4 NEW VALUE
24. 12 使用DUAL表
24.13 DECODE函数
24.14 日期转换
24.15 执行一系列SQL文件
24.16 在SQL脚本文件中加注释
24. 17 高级报表
24.18 小结
24. 19 问与答
24.20 工作室
24.20.1 测验
24.20.2 练习
第25章 Oracle的PL/SQL语言简介
25.1 PL/SQL介绍
25.2 PL/SQ L中的数据类型
25.2.1 字符串数据类型
25.2.2 数值数据类型
25.2.3 二进制数据类型
25.2.4 日期数据类型
25.2.5 布尔型
25.2.6 行号(ROWID)
25.3 PL/SQL程序块结构
25.4 DECLAREd部分
25.4.1 变量赋值
25.4.2 常量赋值
25.4.3 游标的定义
25.4.4 %TYPE属性
25.4.5 % ROWTYPE属性
25.4.6 %ROWCOUNT属性
25.5 PROCEDURE部分
25.5.1 BEGIN...END语句
25.5.2 游标控制命令
25.5.3 条件语句
25.6 EXCEPTION部分
25.6.1 异常事件的触发
25.6.2 异常事件处理程序的执行
25.6.3 插入注解
25.6.4 PL/SQL程序块的执行
25.6.5 为用户显示输出结果
25.7 PL/SQL中的事务控制
25.8 PL/SQL程序的完整介绍
25.8.1 样表和数据
25.8.2 PL/SQL程序块实例
25.8.3 另一个实例
25.9 存储过程、程序包和触发器
25.9.1 存储过程样本
25.9.2 程序包样本
25.9.3 触发器样本
25.10 小结
25.11 问与答
25.12.1 工作室
25.12.1 测验
25.12.2 练习
第26章 Transact SQL介绍
26.1 Transact-SQL概述
26.2 对ANSI SQL语言的扩充
26.2.1 Transact-SQL面向哪些用户
26.2.2 Transact-SQL的基本构成
26.3 数据类型
26.3.1 字符串类型
26.3.2 数值数据类型
26.3.3 日期数据类型
26.3.4 货币数据类型
26.3.5 二进制串
26.3.6 位(bit)——一种逻辑数据类型
26.4 使用 Transact-SQL访问数据库
26.4.1 BASEBALL数据库
26.4.2 局部变量的声明
26.4.3 全局变量的声明
26.4.4 变量的使用
26.4.5 PRINT命令
26.5 建立程序流程控制
26.5.1 BEGIN和END语句
26.5.2 IF...ELSE语句
26.5.3 EXISTS条件
26.5.4 测试查询结果
26.5.5 WHILE循环
26.5.6 BREAK命令
26.5.7 CONTINUE命令
26.5.8 使用WHILE循环滚动访问一个表
26.6 Transact-SQL通配符
26.7 使用COMPUTE命令创建合计报表
26.8 日期转换
26.9 SQL Server的诊断工具——SET命令
26.10 小结
26.11 问与答
26.12 工作室
26.12.1 测验
26.12.2 练习
第27章 Visual C++和Delphi中的动态SQL语言
27.1 几个应用程序开发工具简介
27.1.1 ODBC
27.1.2 Personal Oracle8
27.1.3 InterBase SQL
27.1.4 VisualC++
27.1.5 Delphi
27.2 开始运行Oracle和InterBase
27.3 创建数据库
27.4 用Microsoft Query执行连接
27.5 使用 VisualC++和SQL
27.6 使用 Delphi和SQL
27.7 小结
27.8 问与答
27.9 工作室
27.9.1 测验
27.9.2 练习
第28章 MySQL介绍
28.1 MySQL管理
28.1.1 MySQL安装
28.1.2 启动和停止MySQL
28.1.3 MySQL的初始
28.2 MySQL客户端程序
28.2.1 连接数据库
28.2.2 命令行选项
28.2.3 输入MySQL客
28.2.4 执行命令的历史记录
28.2.5 批处理模式
28.2.6 SHOW命令
28.3 MySQL实用程序
28.4 小结
28.5 问与答
28.6 工作室
28.7.1 测验
28.8.2 练习
附加篇回顾
附录
附录A 答案
附录B 创建表的实例代码
附录C 生成Plpulate表中数据的代码
附录D 第27章的C++程序源代码
附录E 第27章的Delphi程序源代码
附录F 常用SQL命令术语
附录G ASCll码表
附录H 相关资源
猜您喜欢