ORACLE存储过程实战之一:入门
2008-01-12 15:06
435 查看
1.基本结构
CREATE OR REPLACE PROCEDURE 存储过程名字
(
参数1 IN NUMBER,
参数2 IN NUMBER,
参数3 OUT NUMBER
) IS
变量1 INTEGER := 默认值;
变量2 DATE;
BEGIN
...
EXCEPTION
WHEN 异常类别 THEN
...
WHEN OTHERS THEN
...
END 存储过程名字;
2.基本操作
变量赋值 V_TEST := 1;
动态赋值 SELECT COL1,COL2,... INTO VAR1,VAR2,... FROM ... WHERE ...;
字符相加 'STRING1' || 'STRING2';
相等判断 =而不是==;
逻辑判断 AND,OR,>,<,<>;
打印输出 dbms_output.put_line();
是否为空 V_TEST IS (NOT) NULL;
提交回滚 COMMIT/ROLLBACK;
异常捕捉 BEGIN ... EXCEPTION WHEN ... THEN ... END;
3.IF 判断
IF (判断条件) THEN
BEGIN
...
END;
ELSIF THEN
...
ELSE
...
END IF;
4.WHILE 循环
WHILE (判断条件) LOOP
BEGIN
...
END;
END LOOP;
5.FOR 循环
FOR X IN (SELECT col1,col2 ...) LOOP
BEGIN
引用X.col1、X.col2
...
END;
END LOOP;
6.常见FUNCTION
以下列出的是一些常用函数的普通用法,并不是按照ORACLE函数标准进行说明的,所以有些用法并不全面,只是列举了最常用的情况;
SYSDATE:用来得到系统的当前日期;
TO_NUMBER(STR):将字符串转换成数字;若转换不成功,则抛错:ORA-01722: invalid number;
TO_CHAR(?):?可支持很多的类型,比如NUM,DATE……;DATE用得比较多,一般来说有如下用法:
TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS'):将当前日期按照格式输出完整字符串;其中的日期格式可以自行定义;
TO_DATE(STR,FORMAT):对字符串按照一定格式解析成Date型;
NVL(col,defaultValue):对col判断是否为NULL,若为NULL,则返回defaultValue;
CONCAT(STR1,STR2):连接两个字符串,功能与||相同;
LENGTH(STR):返回字符串的长度,其中中文字符的长度计算要视DB的编码而定,在GBK编码下,中文也算1个字符;
若需要中文字符长度算2个字符,则可以用LENGTHB(STR)代替;
简单来说,LENGTH返回字符长度;LENGTHB返回字节长度;
SUBSTR(str,start,count):截取子字符串,从start开始,取count个;
start为0和1的效果是一样的,都是从str的第一个字符开始截取;
若start>=LENGTH(str),直接返回空,不会抛错;
INSTR(STR1,STR2,I,J):在一个字符串中搜索指定的字符,返回发现指定的字符的位置;
STR1:被搜索的字符串
STR2:希望搜索的字符串
I:搜索的开始位置,默认为1
J:第几次出现的位置,默认为1
LOWER/UPPER(STR):将字符串全部转成小写或者大写;在GBK编码下,该函数对中文无效;
LTRIM/RTRIM(STR):删除左边货右边出现的空格字符串;
FLOOR(NUMBER):对给定的数字取整数;
MOD(num1,num2):返回num1除以num2的余数;num1和num2可以带有小数位;返回的值也可能有小数位;
ROUND(num):对num四舍五入取值;
TRUNC(num):对num截取整数,去掉小数位,不进行四舍五入;功能与FLOOR类似;当然也可以在参数中指定精度;
TRUNC(Date):对date截取到天,去掉小时分钟之类的,其返回类型仍然为Date;类似的,也可以在参数中指定Date截取级别,比如'hh';
ADD_MONTHS(Date,num):对Date加上num个月,num可以为负数,表示减去几个月;
num可以有小数位,但是并不会起效,效果相当于ADD_MONTHS(Date,TRUNC(num));
CHARTOROWID/ROWIDTOCHAR:将字符数据类型转换为ROWID类型或者相反;
AVG/MIN/MAX/SUM/COUNT(DISTINCT|ALL col):对某字段取平均、最小、最大、求和、计数;默认为ALL,若需要对不重复值运算,则用DISTINCT参数;
CASE WHEN ... THEN ...
WHEN ... THEN ...
ELSE ...
END:根据不同条件取不同的值,与JAVA中的CASE也很类似;
CREATE OR REPLACE PROCEDURE 存储过程名字
(
参数1 IN NUMBER,
参数2 IN NUMBER,
参数3 OUT NUMBER
) IS
变量1 INTEGER := 默认值;
变量2 DATE;
BEGIN
...
EXCEPTION
WHEN 异常类别 THEN
...
WHEN OTHERS THEN
...
END 存储过程名字;
2.基本操作
变量赋值 V_TEST := 1;
动态赋值 SELECT COL1,COL2,... INTO VAR1,VAR2,... FROM ... WHERE ...;
字符相加 'STRING1' || 'STRING2';
相等判断 =而不是==;
逻辑判断 AND,OR,>,<,<>;
打印输出 dbms_output.put_line();
是否为空 V_TEST IS (NOT) NULL;
提交回滚 COMMIT/ROLLBACK;
异常捕捉 BEGIN ... EXCEPTION WHEN ... THEN ... END;
3.IF 判断
IF (判断条件) THEN
BEGIN
...
END;
ELSIF THEN
...
ELSE
...
END IF;
4.WHILE 循环
WHILE (判断条件) LOOP
BEGIN
...
END;
END LOOP;
5.FOR 循环
FOR X IN (SELECT col1,col2 ...) LOOP
BEGIN
引用X.col1、X.col2
...
END;
END LOOP;
6.常见FUNCTION
以下列出的是一些常用函数的普通用法,并不是按照ORACLE函数标准进行说明的,所以有些用法并不全面,只是列举了最常用的情况;
SYSDATE:用来得到系统的当前日期;
TO_NUMBER(STR):将字符串转换成数字;若转换不成功,则抛错:ORA-01722: invalid number;
TO_CHAR(?):?可支持很多的类型,比如NUM,DATE……;DATE用得比较多,一般来说有如下用法:
TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS'):将当前日期按照格式输出完整字符串;其中的日期格式可以自行定义;
TO_DATE(STR,FORMAT):对字符串按照一定格式解析成Date型;
NVL(col,defaultValue):对col判断是否为NULL,若为NULL,则返回defaultValue;
CONCAT(STR1,STR2):连接两个字符串,功能与||相同;
LENGTH(STR):返回字符串的长度,其中中文字符的长度计算要视DB的编码而定,在GBK编码下,中文也算1个字符;
若需要中文字符长度算2个字符,则可以用LENGTHB(STR)代替;
简单来说,LENGTH返回字符长度;LENGTHB返回字节长度;
SUBSTR(str,start,count):截取子字符串,从start开始,取count个;
start为0和1的效果是一样的,都是从str的第一个字符开始截取;
若start>=LENGTH(str),直接返回空,不会抛错;
INSTR(STR1,STR2,I,J):在一个字符串中搜索指定的字符,返回发现指定的字符的位置;
STR1:被搜索的字符串
STR2:希望搜索的字符串
I:搜索的开始位置,默认为1
J:第几次出现的位置,默认为1
LOWER/UPPER(STR):将字符串全部转成小写或者大写;在GBK编码下,该函数对中文无效;
LTRIM/RTRIM(STR):删除左边货右边出现的空格字符串;
FLOOR(NUMBER):对给定的数字取整数;
MOD(num1,num2):返回num1除以num2的余数;num1和num2可以带有小数位;返回的值也可能有小数位;
ROUND(num):对num四舍五入取值;
TRUNC(num):对num截取整数,去掉小数位,不进行四舍五入;功能与FLOOR类似;当然也可以在参数中指定精度;
TRUNC(Date):对date截取到天,去掉小时分钟之类的,其返回类型仍然为Date;类似的,也可以在参数中指定Date截取级别,比如'hh';
ADD_MONTHS(Date,num):对Date加上num个月,num可以为负数,表示减去几个月;
num可以有小数位,但是并不会起效,效果相当于ADD_MONTHS(Date,TRUNC(num));
CHARTOROWID/ROWIDTOCHAR:将字符数据类型转换为ROWID类型或者相反;
AVG/MIN/MAX/SUM/COUNT(DISTINCT|ALL col):对某字段取平均、最小、最大、求和、计数;默认为ALL,若需要对不重复值运算,则用DISTINCT参数;
CASE WHEN ... THEN ...
WHEN ... THEN ...
ELSE ...
END:根据不同条件取不同的值,与JAVA中的CASE也很类似;
相关文章推荐
- python3 [入门基础实战] 爬虫入门之xpath爬取脚本之家python栏目
- mybatis实战教程(mybatis in action),mybatis入门到精通
- Win 2008 R2实战之Branch Cache入门 推荐
- Git入门:安装环境 版本回退 仓库实战 搭建git服务端
- Solr实战之(一)Solr入门
- React入门指引与实战
- mybatis实战教程(mybatis in action),mybatis入门到精通
- Spark入门实战系列 spark编程模型--IDEA搭建及实战
- 土人系列AS入门教程--实战篇
- OpenStack入门到实战视频教程全集下载(罗勇老师经典教程系列)
- Docker系列一之基础快速入门企业实战
- Android开发入门——推箱子游戏开发实战(十三)
- [置顶] Docker学习总结(2)——Docker实战之入门以及Dockerfile(二)
- Spring3开发实战 之 第一章:Spring入门
- J2ME蓝牙程序开发实战入门
- 正则表达式从入门到实战
- Spring boot入门实例 简易登录(精通Spring+4.x++企业应用开发实战 学习笔记二)
- mybatis实战教程(mybatis in action),mybatis入门到精通
- python3 [爬虫入门实战]爬虫之mongoDB数据库的安装配置与可视化