写在前面

这段时间工作最长接触到的就是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包

包是有包头和包体组成的一组具有共性的函数或者过程。

  1. 声明包
CREATE OR REPLACE PACKAGE PKGTEST is
TYPE refcursor IS REF CURSOR;
procedure add();
procedure update();
procedure get();
end pkgTEST;
  1. 定义包体
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常用存储过程写法的更多相关文章

  1. 【Oracle】存储过程写法小例子

    1.存储过程的基本语法: CREATE OR REPLACE PROCEDURE 存储过程名(param1 in type,param2 out type) IS 变量1 类型(值范围); 变量2 类 ...

  2. PB中用oracle的存储过程返回记录集做数据源来生成数据窗口,PB会找不到此存储过程及不能正常识别存储过程的参数问题(转)

    (转)在PB中用oracle的存储过程返回记录集做数据源来生成数据窗口 首先oracle的存储过程写法与MSSQL不一样,差别比较大. 如果是返回数据集的存储过程则需要利用oracle的包来定义游标. ...

  3. Oracle的存储过程基本写法

    转: Oracle的存储过程基本写法 目录 1.1,Oracle存储过程简介: 1.2,创建存储过程的语法: 2.0,游标的使用.看到的一段解释很好的概念,如下: 回到顶部 1.1,Oracle存储过 ...

  4. Oracle常用傻瓜问题1000问

    Oracle常用傻瓜问题1000问 大家在应用ORACLE的时候可能会遇到很多看起来不难的问题, 特别对新手来说, 今天我简单把它总结一下, 发布给大家, 希望对大家有帮助! 和大家一起探讨, 共同进 ...

  5. oracle常用密令大全

    1.create user username identified by password;//建用户名和密码oracle ,oracle 2.grant connect,resource,dba t ...

  6. Oracle常用语法

    Oracle常用语句语法汇总 Oracle10g 1 第一章Oracle命令 a) 系统管理员连接 conn */* as sysdba b) 查询当前用户 show user c) 创建新用户 cr ...

  7. oracle常用SQL语句(汇总版)

    Oracle数据库常用sql语句 ORACLE 常用的SQL语法和数据对象一.数据控制语句 (DML) 部分 1.INSERT (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, ...

  8. oracle常用的数据字典

    一.oracle数据字典主要由以下几种视图构成:1.user视图以user_为前缀,用来记录用户对象的信息 2.all视图以all_为前缀,用来记录用户对象的信息及被授权访问的对象信息 3.dba视图 ...

  9. 懵懂oracle之存储过程

    作为一个oracle界和厨师界的生手,笔者想给大家分享讨论下存储过程的知识,因为在我接触的通信行业中,存储过程的使用还是占据了一小块的地位. 存储过程是什么?不得不拿下百度词条的解释来:"存 ...

随机推荐

  1. go语言之进阶篇拷贝文件案例

    1.文件案例:拷贝文件 示例: package main import ( "fmt" "io" "os" ) func main() { ...

  2. C# DevExpress TabPane【转】

    DevExpress TabPane能够快速简单地实现了Tab窗口的功能,相对XtraTabControl来说功能较为简单,也能够更快实现功能. 1.添加TabPane控件 将它拖到form即可. 2 ...

  3. iOS开发-Launch Image和Launch Screen

    Launch Image是App的启动图片,LaunchScreen是iOS8之后的功能,两者都可以设置app的启动图片.iOS8之后官方的推荐了使用Launch screen.xib,在xib的中通 ...

  4. 七牛云存储 qiniu 域名 回收 文件上传 备份 下载 MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  5. Gson Json 序列号 最常用的功能 MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  6. RV ItemDecoration 分割线 简介 MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  7. 遛老虎网 http://6laohu.com/

    遛老虎网 http://6laohu.com/

  8. JavaScript 实现打印,打印预览,打印设置

    WebBrowser是IE内置的浏览器控件,无需用户下载. 一.WebBrowser控件 <object ID='WebBrowser' WIDTH=0 HEIGHT=0 CLASSID='CL ...

  9. 使用Java语言开发微信公众平台(三)——被关注回复与关键词回复

    在上一篇文章中,我们实现了文本消息的接收与响应.可以在用户发送任何内容的时候,回复一段固定的文字.本章节中,我们将对上一章节的代码进行适当的完善,同时实现[被关注回复与关键词回复]功能. 一.微信可提 ...

  10. [Canvas]碰撞球 增加小球间碰撞检测

    请点此下载代码并用Chrome或是Firefox打开index.html 图例: 代码: <!DOCTYPE html> <html lang="utf-8"&g ...