Oracle培训教材


一. SQL 语言简介

1. SQL 概述

SQL 是一种面向数据库的通用数据处理语言规范,能完成以下几类功能:提取查询数据,插入修改删除数据,生成修改和删除数据库对象,数据库安全控制,数据库完整性及数据保护控制。

数据库对象包括表、视图、索引、同义词、簇、触发器、函数、过程、包、数据库链、快照等(表空间、回滚段、角色、用户)。数据库通过对表的操作来管理存储在其中的数据。

2. 数据库查询

  1. 用 SELECT 语句从表中提取查询数据。语法为

SELECT [DISTINCT] {column1,column2,…} FROM tablename WHERE {conditions} GROUP BY {conditions} ORDER BY {expressions} [ASC/DESC];

说明: SELECT 子句用于指定检索数据库的中哪些列, FROM 子句用于指定从哪一个表或视图中检索数据。

  1. SELECT 中的操作符及多表查询 WHERE 子句。 (LIKE,IS,…)

WHERE 子句中的条件可以是一个包含等号或不等号的条件表达式,也可以是一个含有 IN 、 NOT IN 、 BETWEEN 、 LIKE 、 IS NOT NULL 等比较运算符的条件式,还可以是由单一的条件表达通过逻辑运算符组合成复合条件。

比较操作符 = > < >= <= != <>

SQL 操作符 BETWEEN … AND … IN LIKE IS NULL

NOT BETWEEN … AND… NOT IN NOT LIKE IS NOT NULL

逻辑操作符 AND OR NOT

  1. ORDER BY 子句

ORDER BY 子句使得 SQL 在显示查询结果时将各返回行按顺序排列,返回行的排列顺序由 ORDER BY 子句指定的表达式的值确定。

  1. 连接查询

利用 SELECT 语句进行数据库查询时,可以把多个表、视图的数据结合起来,使得查询结果的每一行中包含来自多个表达式或视图的数据,这种操作被称为连接查询。

连接查询的方法是在 SELECT 命令的 FROM 子句中指定两个或多个将被连接查询的表或视图,并且在 WHERE 子句告诉 ORACLE 如何把多个表的数据进行合并。根据 WHERE 子句中的条件表达式是等还是不等式,可以把连接查询分为等式连接和不等式连接。

  1. 子查询

如果某一个 SELECT 命令(查询 1 )出现在另一个 SQL 命令(查询 2 )的一个子句中,则称查询 1 是查询 2 的子查询。

3. 基本数据类型( NUMBER,VARCHAR2,DATE )

** ** O RACEL 支持下列内部数据类型:

l VARCHAR2 变长字符串,最长为 2000 字符。

l NUMBER 数值型。

l LONG 变长字符数据,最长为 2G 字节。

l DATE 日期型。

l RAW 二进制数据,最长为 255 字节。

l LONG RAW 变长二进制数据,最长为 2G 字节。

l ROWID 二六进制串,表示表的行的唯一地址。

l CHAR 定长字符数据,最长为 255 。

4. 常用函数用法:

** ** 一个函数类似于一个算符,它操作数据项,返回一个结果。函数在格式上不同于算符,它个具有变元,可操作 0 个、一个、二个或多个变元,形式为:

函数名(变元,变元,…)

函数具有下列一般类形:

l 单行函数

l 分组函数

1) 单行函数对查询的表或视图的每一行返回一个结果行。它有数值函数,字符函数,日期函数,转换函数等。

2) 分组函数返回的结果是基于行组而不是单行,所以分组函数不同于单行函数。在许多分组函数中可有下列选项:

l DISTRNCT 该选项使分组函数只考虑变元表达式中的不同值。

l ALL 该选项使分组函数考虑全部值,包含全部重复。

全部分组函数(除 COUNT ( * )外)忽略空值。如果具有分组函数的查询,没有返回行或只有空值(分组函数的变元取值的行),则分组函数返回空值。

l 单行函数

  1. 数字函数

ABS 取绝对值 POWER 乘方 LN 10 为底数取冪

SQRT 平方根 EXP e 的 n 次乘方 LOG(m,n) m 为底数 n 取冪

数学运算函数 :ACOS ATAN ATAN2 COS COSH SIGN SIN SINH TAN TANH

CEIL 大于或等于取整数

FLOOR 小于或等于取整数

MOD 取余数

ROUND(n,m) 按 m 的位数取四舍五入值如果 round( 日期 ): 中午 12 以后将是明天的日期 . round(sysdate,'Y') 是年的第一天

TRUNC(n,m) 按 m 的位数取前面的数值如果 trunc( 日期 ), 确省的是去掉时间

  1. 字符函数

CHR 按数据库的字符集由数字返回字符

CONCAT(c1,c2) 把两个字符 c1,c2 组合成一个字符 , 和 || 相同

REPLACE(c,s,r) 把字符 c 里出现 s 的字符替换成 r, 返回新字符

SUBSTR(c,m,n) m 大于 0, 字符 c 从前面 m 处开始取 n 位字符 ,m 等于 0 和 1 一样 ,

m 小与 0, 字符 c 从后面 m 处开始取 n 位字符

TRANSLATE(c,f1,t1) 字符 c 按 f1 到 t1 的规则转换成新的字符串

INITCAP 字符首字母大写 , 其它字符小写

LOWER 字符全部小写

UPPER 字符全部大写

LTRIM(c1,c2) 去掉字符 c1 左边出现的字符 c2

RTRIM(c1,c2)

TRIM(c1,c2) 去掉字符 c1 左右两边的字符 c2

LPAD(c1,n,c2) 字符 c1 按制定的位数 n 显示不足的位数用 c2 字符串替换左边的空位

RPAD(c1,n,c2)

  1. 日期函数

ADD_MONTHS(d,n) 日期值加 n 月

LAST_DAY(d) 返回当月的最后一天的日期

MONTHS_BETWEEN(d1,d2) 两个日期值间的月份 ,d1<d2 返回负数

NEXT_DAY(d) 返回日期值下一天的日期

SYSDATE 当前的系统时间

DUAL 是 SYS 用户下一个空表,它只有一个字段 dummy

  1. 转换函数 (1)

TO_CHAR(date,' 日期显示格式 ')

TO_CHAR(number) 用于显示或报表的格式对齐

TO_DATE(char,' 日期显示格式 ')

TO_LOB 把 long 字段转换成 lob 字段

TO_NUMBER(char) 用于计算或者比较大小

5)<SPAN style="FON

Published At
Categories with 数据库类
Tagged with
comments powered by Disqus