一.单行函数
字符函数
(1).LOWER() 字符小写
(2).UPPER() 字符大写
(3).INITCAP() 首字符大写
(4).CONCAT() 字符串连接
(5).SUBSTR() 字符串截取
(6).LENGTH() 返回字符串长度
(7).INSTR() 返回字符串的位置
(8).LPAD() 左对齐
(9).RPAD() 右对齐
(10).TRIM() 去除字符串首尾的字符
(11).REPLACE() 替换字符串中所有的字符
2.数字函数
(1).round() 四舍五入
(2).trunc() 截取
(3).mod() 取余
3.日期函数
(1).sysdate 返回当前日期和时间
(2).months_between() 两个日期相差的月数
(3).add_months() 向指定日期中加上若干月数
(4).next_day() 指定日期的下一个日期
(5).last_day() 本月的最后一天
(6).round() 日期四舍五入
(7).trunc() 日期截断
4.转换函数
(1).to_char 转换为字符
(2).to_date 转换为日期
(3).to_number 转换为数值
5.通用函数
(1).nvl() 将控制转换为一个已知的值,可以使用的数据类型有日期,字符,数字
(2).nvl2()
(3).nullif()
(4).coalesce()
二.多行函数(分组函数)
分组函数作用于一组数据,并对一组数据返回一个值
分组函数忽略空值,NVL函数使分组函数无法忽略空值,例如avg(nvl(expr1,expr2))
(1).avg() 求平均值
(2).count() 求记录总数
a.count(expr) 返回expr不为空的记录总数
b.count(*) 返回表中记录总数
c.count(distinct expr) 返回expr非空且不重复的记录总数
(3).max() 求最大值
(4).min() 求最小值
(5).stddev()
(6).sum() 求和值
可以使用group by子句将表中的数据分成若干组,在select列表中所有未包含在组函数中的列都应该包含在group by 子句中(所有包含于select列表中而未包含于组函数中的列都应该包含在group by子句中),包含在group by 子句中的列不必包含在select 列表中
不能在where子句中使用分组函数,可以在having子句中使用分组函数
group by. . having不分前后顺序
三.条件表达式
(1).case ...when ...then
when ... then
else ...
end
(2).decode(expression,search1,result1[,search2,result2...])
四.多表查询
笛卡尔积 查询中省略连接条件,表行数相乘为返回结果
多表查询有相同列时,列名之前需加入表前缀
内连接
a.等值连接
b.连接N个表至少需要N-1个连接条件
c.非等值连接
4.外连接
a.使用外连接可以查询不满足连接条件的数据
b.外连接的符号是(+), 理解"(+)"的位置:以左外连接为例,因为左表需要返回更多的记录, 右表就需要"加上"更多的记录,所以在右表的连接条件上"(+)"
两边都加上"(+)"符号,会发生语法错误
这种语法为oracle所独有,不能在其他数据库中使用,其他数据库需使用SQL 1999语法标准
c.左外连接
d.右外连接
e.全外连接
5.自连接
五.子查询
子查询要包含在括号内
讲子查询放在比较条件的右侧
单行 操作符对应单行子查询,多行操作符对应多行子查询
单行子查询操作符:
>
<
>=
<=
<>
=
多行子查询操作符:
in 等于列表中的任意一个
any 和子查询返回的任意一个值比较
all 和子查询返回的所有值比较
六.创建和管理表
命名规则
必须以字母开头
必须在1-30个字符之间
必须只能包含A-Z,a-z,0-9,_,$和#
必须不能和用户定义的其他对象重名
必须不能是oracle的保留关键字
数据类型
VARCHAR2(SIZE) 可变长字符数据 CHAR(SIZE) 定长字符数据 NUMBER(P,S) 可变长数值数据 DATE 日期型数据 LONG 可变长字符数据,最大可达到2G CLOB 可变长字符数据,最大可达到4G RAW(LONG RAW) 原始的二进制数据 BLOB 二进制数据,最大可达到4G BFILE 存储外部文件的二进制数据,最大可达到4G ROWID 行地址
3.
语句 | 描述 |
CREATE TABLE | 创建表 |
ALTER TABLE | 修改表 |
DROP TABLE | 删除表 |
RENAME TO | 重命名表 |
TRUNCATE TABLE | 删除表中的所有数据,并释放存储空间 |
七.数据处理
1.insert into .....values (.....) 添加
2.insert into .....select ...from ...where .... 子查询方式添加
3.update ....set .... where ....... 更改
4.delete .... from ...where 删除
5.commit 提交
6.savepoint 保存点
7.rollback 回滚
八.约束
1.约束是表级的强制规定
2.约束类型:
a.not null
b.unique 可以为空
c.primary key = not null+unique
d.foreign key
e.check
3.如果不指定约束名,oracle server自动按照SYS_Cn的格式指定约束名
4.创建和修改约束
a.建表的同时
b.建表之后
5.可以在表级或列级定义约束
a.列级约束只能作用在一个列上
b.表级约束可以作用在多个列上(或者一个列上)
c.列级约束必须跟在列的定义后面,表约束不与列一起,而是单独定义
d.非空约束(not null)只能定义在列上
e.foreign key约束关键字:
--foreign key在表级指定子表中的列
--references 标示在父表中的列
--on delete cascade(级联删除) 当父表中的列被删除时,子表中相对应的列也被删除
--on delete set null(级联置空) 子表中相应的列为空
6.可以通过数据字典视图查看约束
7.添加和删除约束
a.添加或删除约束,但不能修改约束
b.有效化(enable)或无效化(disable)约束
c.添加not null 约束要使用modify语句
8.查询约束
a.user_constraints
b.user_cons_columns
九.视图
1.top-n分析
对rownum(伪列)只能使用<或者<=,而用>,>=,= 都不能返回数据
2.简单视图和复杂视图
a. 复杂视图中包含分组函数
b.可以在简单视图中执行DMS操作
c.当视图定义中包含以下元素之一时不能使用delete
--组函数
--group by 子句
--distinct 关键字
--rownum 伪列
十.PL/SQL编程
一. PLSQL块类型
1.匿名块
2.存储过程
语法结构
declare( 可选部分)
--声明变量部分
begin
--sql语句执行部分
exception(可选部分)
--异常处理部分
end; 结束
/
3.函数(有返回值)
二.变量
1.临时存储数据
2.操作存储的数据
3.重用性
4.变量命名规则
--字母开头
--可以包含字母或者数字
--可以包含特殊字符'$','_','#'
--不能超过30个字符
--不能包含保留关键字
5.变量用处
--declare时进行声明
--在begin执行阶段使用和分配值
--作为子程序参数进行传递
--作为输出参数
6.变量赋值规则
identifier [constant] datatype [not null]
[:=|default expr];
赋值':=' 或者default 提供默认值
%type 根据表列的数据类型声明(类型与长度与列的类型一致)
identifier table.column_name%type;
7.变量类型
a.标量变量
--日期型
--数字型
--字符型
--布尔型(boolean)
b.复合变量
--%type 引用数据库列的数据类型
--%rowtype 表示该类型为行数据类型,存储的时候为一行数据,一行有很多列,相当于表中的一行数 据,也可以为游标中的一行数据
v_name table_name%rowtype;
v_name cursor_name%rowtype;
可以依据表或者游标来定义变量类型
--record 记录类型
type record_type is record(.......);
record_name record_type;--变量名 变量类型(记录类型)
一个记录类型的变量只能保存从数据库中查询出的一行记录,若查询出了多行记录,就会出 现错误
c.参照变量
三.流程控制
1.条件判断
if......then...
[elsif.....then];
[else......];
end if;
case 不管简单case还是搜索case每句结束后需要加';'分号,同时结尾是end case;
例如:
DECLARE
grade CHAR(1);
BEGIN
grade := 'B';
CASE grade
WHEN 'A' THEN DBMS_OUTPUT.PUT_LINE('Excellent');
WHEN 'B' THEN DBMS_OUTPUT.PUT_LINE('Very Good');
WHEN 'C' THEN DBMS_OUTPUT.PUT_LINE('Good');
WHEN 'D' THEN DBMS_OUTPUT.PUT_LINE('Fair');
WHEN 'F' THEN DBMS_OUTPUT.PUT_LINE('Poor');
ELSE DBMS_OUTPUT.PUT_LINE('No such grade');
END CASE;
END;
/
2.逻辑循环
a. loop
.......
[ exit ...[exit when...]]
end loop;
b. while....loop
.....
end loop;
c. for counter in [reverse] values1..values2
loop
.......
end loop;
四.存储过程
create [or replace] prodecure
[parameter list] --参数列表
is|as
[变量声明]
begin
.........
[exception
............]
end;
过程参数的三种形式:
a. in 用于接受调用程序的值,默认的参数形式
b. out 用于向调用程序返回值
c. 用于接受调用程序的值,并向调用程序返回新值
过程参数有IN/OUT/IN OUT三种类型,其中IN类型可以被过程体引用,但不能改写值;OUT类型不可被过程体引用,但可改写值;IN OUT 既可以被过程体引用,又可以改写值.
在调用in out类型时,调用过程插入参数时,不能直接用常量。必须用变量。这样才能接收out返回来的值。同理:用out的也不能直接用常量。
十一.游标
1.隐式游标
a.隐式游标由PL/SQL自动定义,打开和关闭,名称为SQL
b.在PL/SQL程序中执行DML SQL语句时自动创建
c.通过检查隐式游标的属性可以获得最近执行的DML语句的信息
d.属性
%found SQL语句影响了一行或者多行时为TRUE
%notfound SQL语句没有影响任何行时为TRUE
%rowcount SQL语句影响的行数
%isopen 游标是否打开,始终为false
select into 语句不会触发隐式游标属性而是直接转入异常处理阶段
2.显示游标--逐行处理
显示游标用于处理返回多行的查询
显示游标可以删除和更新活动集中的行
a.声明游标 cursor .....is select ......
b.打开游标 open cursor_name
c.提取游标 fetch cursor_name into ....
d.关闭游标 close cursor_name
游标的FOR循环
PL/SQL语言提供了游标FOR循环语句,自动执行游标的OPEN、FETCH、CLOSE语句和循环语句的功能;当进入循环时,游标FOR循环语句自动打开游标,并提取第一行游标数据,当程序处理完当前所提取的数据而进入下一次循环时,游标FOR循环语句自动提取下一行数据供程序处理,当提取完结果集合中的所有数据行后结束循环,并自动关闭游标。
格式:
FOR index_variable IN cursor_name[(value[, value]…)] LOOP
-- 游标数据处理代码
END LOOP;
其中:
index_variable为游标FOR 循环语句隐含声明的索引变量,该变量为记录变量,其结构与游标查询语句返回的结构集合的结构相同。在程序中可以通过引用该索引记录变量元素来读取所提取的游标数据,index_variable中各元素的名称与游标查询语句选择列表中所制定的列名相同。如果在游标查询语句的选择列表中存在计算列,则必须为这些计算列指定别名后才能通过游标FOR 循环语句中的索引变量来访问这些列数据。
注:不要在程序中对游标进行人工操作;不要在程序中定义用于控制FOR循环的记录。
游标的FOR循环(子查询)
begin
for index_variable IN (subquery)
loop
end loop;
end;
3.REF游标
a.REF游标和游标变量用于处理运行时动态执行的SQL查询
b.创建游标变量的2个步骤:
声明REF游标类型
声明REF游标类型的变量
c.用于声明REF游标类型的语法为:
type <ref_cursor_name> is ref cursor [return <return type>];
强类型有return返回类型
弱类型没有return返回类型
d.打开游标变量的语法:
open cursor_name from select..statement;
十二.函数
1. 函数需要有返回值
2.函数只能接收in参数,而不能接收in out或者out参数
3.形参不能是PL/SQL类型
4.函数的返回类型也必须是数据库类型
5.访问函数的2种方式:
a.通过PL/SQL块
b.使用SQL语句
6.函数调用时参数传递方法:
a.位置表示法 即在调用时按形参的排列顺序,依次写出实参的名称,而将形参与实参关联起来进行传递。用这种方法进行调用,形参与实参的名称是相互独立,没有关系,强调次序才是重要的
格式为
argument_value1[,argument_value2 …]
b.名称表示法 即在调用时按形参的名称与实参的名称,写出实参对应的形参,而将形参与实参关联起来进行传递。这种方法,形参与实参的名称是相互独立的,没有关系,名称的对应关系才是最重要的,次序并不重要
格式为:
argument => parameter [,…]
c.组合传递 即在调用一个函数时,同时使用位置表示法和名称表示法为函数传递参数。采用这种参数传递方法时,使用位置表示法所传递的参数必须放在名称表示法所传递的参数前面。也就是说,无论函数具有多少个参数,只要其中有一个参数使用名称表示法其后所有的参数都必须使用名称表示法
create or replace function name(....argument...type )
return type
is|as
begin
.......
return variable;
end;
使用过程与函数具有如下优点:
1、共同使用的代码可以只需要被编写和测试一次,而被需要该代码的任何应用程序(如:.NET、C++、JAVA、VB程序,也可以是DLL库)调用。
2、这种集中编写、集中维护更新、大家共享(或重用)的方法,简化了应用程序的开发和维护,提高了效率与性能。
3、这种模块化的方法,使得可以将一个复杂的问题、大的程序逐步简化成几个简单的、小的程序部分,进行分别编写、调试。因此使程序的结构清晰、简单,也容易实现。
4、可以在各个开发者之间提供处理数据、控制流程、提示信息等方面的一致性。
5、节省内存空间。它们以一种压缩的形式被存储在外存中,当被调用时才被放入内存进行处理。并且,如果多个用户要执行相同的过程或函数时,就只需要在内存中加载一个该过程或函数。
6、提高数据的安全性与完整性。通过把一些对数据的操作放到过程或函数中,就可以通过是否授予用户有执行该过程或的权限,来限制某些用户对数据进行这些操作。
过程与函数的相同功能有:
1、 都使用IN模式的参数传入数据、OUT模式的参数返回数据。
2、 输入参数都可以接受默认值,都可以传值或传引导。
3、 调用时的实际参数都可以使用位置表示法、名称表示法或组合方法。
4、 都有声明部分、执行部分和异常处理部分。
5、 其管理过程都有创建、编译、授权、删除、显示依赖关系等。
使用过程与函数的原则:
1、如果需要返回多个值和不返回值,就使用过程;如果只需要返回一个值,就使用函数。
2、过程一般用于执行一个指定的动作,函数一般用于计算和返回一个值。
3、可以SQL语句内部(如表达式)调用函数来完成复杂的计算问题,但不能调用过程。所以这是函数的特色。
.函数执行方法:
1.作为参数传递给子程序
execute dbms_output.put_line(function(parameter));
2.使用局部变量赋值
declare var type;
begin
var:=function(parameter);
end;
3.在SQL语句中作为表达式使用
4.使用本地变量
variable var type;
execute :var:=function(parameter);
.在SQL语句中调用函数限制条件
1.参数只能使用位置传递法
2.必须有执行函数的权限
3.只接收IN类型的参数,同时返回SQL的数据类型而非PL/SQL类型(复合记录类型,表类型,参数类型游标这种)
4.函数只能有一个返回值(return type)
十三.程序包
1.程序包是对相关过程,函数,变量,游标和异常等对象的封装
2.程序包有规范和主体两部分组成
十四.触发器
1.DML触发器(insert,update,delelte):
a.语句触发器
raise_application_error(argument1,argument2) oracle提供的抛错误过程,接受两个参数
第一个参数-20000~-20999之间
第二个参数为提示错误信息
使用条件谓词
inserting
updating
deleting
b.行触发器
2.系统事件触发器(与系统相关的触发器比如用户登录,退出启动,关闭数据库)
3.DDL触发器