Oracle常用存储过程写法
写在前面
这段时间工作最长接触到的就是Oracle数据库,不论查数据,还是统计、运行job,都离不开PL/SQL 存储过程,下面就整理下经常用到的知识。
一、Function函数
函数是执行非查询语句的方法。
- 创建返回list的function
CREATE OR REPLACE FUNCTION FNTOPWEEKESLIST (
ininttype IN INTEGER,
outcurlist OUT pkgrefcursor.refcursor
)
RETURN INTEGER
IS
Begin
OPEN outcurlist FOR
SELECT t.all, a.bookname
FROM tbbookestimatestats t, tbbook a
WHERE t.intype = ininttype
and t.bookid = a.bookid
and a.freetype = 0;
RETURN 0;
END;
- 创建带分页的返回list的function
CREATE OR REPLACE FUNCTION fn_source_pay_getlist(indtbegin DATE,
indtend DATE,
invarsourcename VARCHAR2,
inintpagesize IN INTEGER,
inintpageindex IN INTEGER,
outintRowCount out integer,
outcurlist OUT pkg_refcursor.ref_cursor)
RETURN INTEGER
as
begin
select count(1)
into outintRowCount
from tbcl_resu_payuser
where source = case
when length(invarsourcename) > 0 then
invarsourcename
else
source
end
and trunc(datetime) >= indtbegin
and trunc(datetime) < indtend;
open outcurlist for
select *
from (select a.*, row_number() over(order by a.datetime) rn
from (select source,
datetime,
payusercnt1,
payusercnt2,
payusercnt3,
payusercnt4
from tbcl_resu_payuser
where source = case
when length(invarsourcename) > 0 then
invarsourcename
else
source
end
and trunc(datetime) >= indtbegin
and trunc(datetime) < indtend
order by datetime) a)
where rn between inintpagesize * (inintpageindex - 1) + 1 and
inintpagesize * inintpageindex;
return 0;
end;
- 返回普通值的function
CREATE OR REPLACE FUNCTION FNACTIVEDAYSUSECNTGET (inintactivetype INTEGER,
inintuserid integer,
outintgetcnt out integer,--总抽奖次数
outintusercnt out integer)--用户抽奖次数
RETURN INTEGER
IS
获取活动当天领取次数
vcnt INTEGER;
BEGIN
SELECT NVL (MAX (cnt), 0)
INTO outintgetcnt
FROM tbactivestats
WHERE logtime = TRUNC (SYSDATE) AND activetype = inintactivetype;
SELECT count(1)
INTO outintusercnt
FROM tbuseractivegiftlog
WHERE userid = inintuserid AND activetype = inintactivetype;
RETURN 0;
END;
或者这样:
CREATE OR REPLACE FUNCTION FNUSERCOSTGET(invarptid IN varchar2,
inintbookid in integer)
RETURN integer
IS
vamount integer;
BEGIN
select nvl(max(amount), 0)
into vamount
from tbuserbookcost
where ptid = lower(invarptid)
and bookid = inintbookid;
return(vamount);
EXCEPTION
WHEN others THEN
return(0);
END;
二、Procedure过程
- 更新update
CREATE OR REPLACE PROCEDURE "ADDUPDATEBOOKLOG" (inintbookid IN INTEGER,
inintfreetype IN INTEGER,
outintresult OUT INTEGER) AS
/*
功能:插入一条记录
传入参数:bookid,freetype
输出参数:是否插入成功
*/
BEGIN
如果存在就更新记录
UPDATE tbupdatebooklog
SET createtime = SYSDATE, freetype = inintfreetype
WHERE bookid = inintbookid;
--如果不存在就插入记录
IF SQL%ROWCOUNT = 0 THEN
INSERT INTO tbupdatebooklog(bookid, createtime, freetype)
VALUES(inintbookid, SYSDATE, inintfreetype);
END IF;
COMMIT;
outintresult := 0;
EXCEPTION
WHEN OTHERS THEN
outintresult := 1;
ROLLBACK;
END AddUPdateBookLog;
或者:
CREATE OR REPLACE PROCEDURE PRBOOKSIGNSTATUSSET(inintBookId integer,
invarSignStatus varchar2,
outintresult out integer) is
begin
update tbbook t
set t\.signstatus = invarSignStatus
where bookId = inintBookId;
commit;
outintresult := 0;
end prbookSignStatusset;
- 插入insert
CREATE OR REPLACE PROCEDURE "PRBOOKTYPEUPDLOGINS" (
inintbookid IN INTEGER,
ininttypeid IN INTEGER,
invatypename IN varchar2,
outintresult OUT INTEGER
)
IS
vcnt INTEGER;
BEGIN
insert into tbbooktypeupdlog(bookid,updatetime,typeid,typename)
values (inintbookid,sysdate,ininttypeid,invartypename);
commit;
outintresult:=0;
END;
三、Package包
包是有包头和包体组成的一组具有共性的函数或者过程。
- 声明包
CREATE OR REPLACE PACKAGE PKGTEST is
TYPE refcursor IS REF CURSOR;
procedure add();
procedure update();
procedure get();
end pkgTEST;
- 定义包体
CREATE OR REPLACE PACKAGE BODY PKGTEST is
TYPE refcursor IS REF CURSOR;
procedure add() IS
BEGIN
...
END;
procedure update() IS
BEGIN
...
END;
procedure get() IS
BEGIN
...
END;
end pkgTEST;
Oracle常用存储过程写法的更多相关文章
- 【Oracle】存储过程写法小例子
1.存储过程的基本语法: CREATE OR REPLACE PROCEDURE 存储过程名(param1 in type,param2 out type) IS 变量1 类型(值范围); 变量2 类 ...
- PB中用oracle的存储过程返回记录集做数据源来生成数据窗口,PB会找不到此存储过程及不能正常识别存储过程的参数问题(转)
(转)在PB中用oracle的存储过程返回记录集做数据源来生成数据窗口 首先oracle的存储过程写法与MSSQL不一样,差别比较大. 如果是返回数据集的存储过程则需要利用oracle的包来定义游标. ...
- Oracle的存储过程基本写法
转: Oracle的存储过程基本写法 目录 1.1,Oracle存储过程简介: 1.2,创建存储过程的语法: 2.0,游标的使用.看到的一段解释很好的概念,如下: 回到顶部 1.1,Oracle存储过 ...
- Oracle常用傻瓜问题1000问
Oracle常用傻瓜问题1000问 大家在应用ORACLE的时候可能会遇到很多看起来不难的问题, 特别对新手来说, 今天我简单把它总结一下, 发布给大家, 希望对大家有帮助! 和大家一起探讨, 共同进 ...
- oracle常用密令大全
1.create user username identified by password;//建用户名和密码oracle ,oracle 2.grant connect,resource,dba t ...
- Oracle常用语法
Oracle常用语句语法汇总 Oracle10g 1 第一章Oracle命令 a) 系统管理员连接 conn */* as sysdba b) 查询当前用户 show user c) 创建新用户 cr ...
- oracle常用SQL语句(汇总版)
Oracle数据库常用sql语句 ORACLE 常用的SQL语法和数据对象一.数据控制语句 (DML) 部分 1.INSERT (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, ...
- oracle常用的数据字典
一.oracle数据字典主要由以下几种视图构成:1.user视图以user_为前缀,用来记录用户对象的信息 2.all视图以all_为前缀,用来记录用户对象的信息及被授权访问的对象信息 3.dba视图 ...
- 懵懂oracle之存储过程
作为一个oracle界和厨师界的生手,笔者想给大家分享讨论下存储过程的知识,因为在我接触的通信行业中,存储过程的使用还是占据了一小块的地位. 存储过程是什么?不得不拿下百度词条的解释来:"存 ...
随机推荐
- win10 下 protobuf 与 qt
编译环境: win10 x64 编译器 :mingw32 cmake 使用场景:Qt4.8.7 下载 protobuf 最新的代码:https://github.com/google/proto ...
- [PowerShell Utils] Remotely install Hyper-V and Failover Cluster feature on a list of windows 2012 servers
Hello everyone, this is the second post of the series. . Background =============== In my environm ...
- iOS开发-仿大众点评iPad侧边导航栏
昨天其实已经写了一篇侧边栏的文章,不过感觉还不是很清晰,这篇文章算是补充吧,iPad上看了大众点评的侧边栏,基本上百分之九十类似,具体效果可参考下图: 对比昨天主要做了两个修改,一个是图片和文字的显示 ...
- centos7.2使用rpm安装jdk8
①下载jdk 去jdk下载页面找到要下载的jdk,用wget下载 wget --no-check-certificate --no-cookies --header "Cookie: ora ...
- C# 键值对数据排序
对于键值对的数据进行排序方法总结. /*使用排序字典,默认只支持升序 SortedDictionary<DateTime, String> dd = new SortedDictionar ...
- 利用vue-cropper做的关于图片裁剪、压缩、上传、预览等做的一个公共组件
公共组件: <template> <div> <div class="upload-box"> <div class="imag ...
- 【Scala】Scala-None-null引发的血案
Scala-None-null引发的血案 Overview - Spark 2.2.0 Documentation Spark Streaming - Spark 2.2.0 Documentatio ...
- 10个在UNIX或Linux终端上快速工作的建议
你有没有惊讶地看到有人在Unix/ Linux中工作得非常快,噼里啪啦的敲键盘,快速的启动命令,飞快地执行命令? 在本文中,我共享了一些在Linux中快速.高效工作所遵循的Unix/ Linux命令实 ...
- 调用百度、高德地图App,百度地图网页版,App定位
https://www.jianshu.com/p/296a3995adc2 https://blog.csdn.net/qq_26598821/article/details/51087785 ht ...
- insta经典滤镜下载
好不容易找到的Insta的经典滤镜源码,贴出来帮大家学习. // // IFImageFilter.m // InstaFilters // // Created by Di Wu on 2/28/1 ...