Oracle存储过程使用总结
1.使用Oracle存储过程查询结果集:
网上写的都是他妈的扯淡!其实一句话就行了,你只要返回一个游标就OK了。具体代码如下:
CREATE OR REPLACE
PROCEDURE PR_ORDER_LIST(
ORDER_ID VARCHAR2,
BEGINDATE VARCHAR2,
ENDDATE VARCHAR2,
CUSTOMER VARCHAR2,
STATUS VARCHAR2,
V_TEMP out sys_refcursor
)
IS
SQLTEXT VARCHAR2(4000);
BEGIN SQLTEXT := 'select s.OrderId,c.CustomerName,s.SendAddress,p.TextValue as BussinessStatus,
NVL(s.UpdateT,s.InsertT) as OrderDate from SaleOrder s
LEFT JOIN CustomerInfo c on s.CustomerId = c.CustomerId and c.CustomerType = ''C''
LEFT JOIN DataParameter p on s.BussinessStatus = p.Code and p.ParameterType = ''BussinessStatus''
where to_char(NVL(s.UpdateT,s.InsertT),''yyyyMMdd'') between '''||BEGINDATE||''' and '''||ENDDATE||''' '; IF ORDER_ID <> '' THEN SQLTEXT := SQLTEXT || ' and s.OrderId like ''%'||ORDER_ID||'%'''; END IF; IF CUSTOMER <> '' THEN SQLTEXT := SQLTEXT || ' and s.CustomerId = '||to_number(CUSTOMER); END IF; IF STATUS <> '' and STATUS <> '' THEN SQLTEXT := SQLTEXT || ' and s.BussinessStatus in ('||STATUS||')'; END IF; SQLTEXT := SQLTEXT || ' order by NVL(s.UpdateT,s.InsertT) desc';
dbms_output.put_line(SQLTEXT); --这个是打印
--execute immediate SQLTEXT; 这个是动态执行sql,写游标可以不用这个,用下面那个
--如果要往变量里面注入值,需要使用上面这个
open V_TEMP FOR SQLTEXT; --彺游标里面注入值 ,这里是注入了一个sql字符串 END;
2.然后就是包的定义,包就相当于C#里面的类,可以封装类型、方法等等。
3.C#程序段使用方法:
/// <summary>
/// 订单列表
/// </summary>
/// <param name="begin"></param>
/// <param name="end"></param>
/// <param name="orderid"></param>
/// <param name="customer"></param>
/// <param name="status"></param>
/// <returns></returns>
public DataTable SaleOrderList(string begin, string end, string orderid, string customer, string status)
{
DBManager vDBManager = new DBManager();
vDBManager.ConnectionOpen();
vDBManager.AddParameter(":begin", begin);
vDBManager.AddParameter(":end", end);
vDBManager.AddParameter(":orderid", orderid);
vDBManager.AddParameter(":customer", customer);
vDBManager.AddParameter(":status", status);
vDBManager.AddOutParameter("V_TEMP", null); //这里注意,一定要是out类型的参数
DataTable dt = vDBManager.RunProcedure("PR_ORDER_LIST", "table1");
vDBManager.ConnectionClose();
return dt;
}
/// <summary>
/// 添加输出参数
/// </summary>
/// <param name="key"></param>
/// <param name="value"></param>
public void AddOutParameter(string key, object value)
{
command.Parameters.Add(new OracleParameter(key, OracleType.Cursor)).Direction = ParameterDirection.Output;
} /// <summary>
/// 执行存储过程
/// </summary>
/// <param name="storedProcName">过程名</param>
/// <param name="parameters">参数</param>
/// <param name="tableName">表名</param>
/// <returns></returns>
public DataSet ExecuteProcName(string storedProcName, string tableName)
{
using (OracleDataAdapter adapter = new OracleDataAdapter())
{
DataSet ds = new DataSet();
adapter.SelectCommand = BuildQueryCommand(storedProcName);
adapter.Fill(ds, tableName);
command.Parameters.Clear();
return ds;
}
}
另外,这个是游标的使用方法:
CREATE OR REPLACE
PROCEDURE PR_MOD_BASE
IS cursor c_base IS
SELECT MIN(INVENTORY_DATE) IDATE,KUNNR,MATNR FROM STOCK_BASE_DATA GROUP BY TO_CHAR(INVENTORY_DATE,'yyyy-MM-dd'),
KUNNR,MATNR HAVING count(*) > 1; c_row c_base%rowtype; BEGIN FOR c_row in c_base loop
DELETE FROM STOCK_BASE_DATA WHERE INVENTORY_DATE = c_row.IDATE and KUNNR = c_row.KUNNR and MATNR = c_row.MATNR;
end loop;
COMMIT;
END;
CREATE OR REPLACE
PROCEDURE "KX_LIST_FROMSTORE_ADD_ITEM"(IN_ORDER_ID NVARCHAR2,
OU_TEMP OUT SYS_REFCURSOR) IS
/*订单转交货的时候用来获取订单行项目带到交货单编辑界面的存储过程*/ BEGIN
OPEN OU_TEMP FOR
SELECT DISTINCT A.DETAILID,
A.ORDERID,
A.PRODUCTID,
PI2.BARCODE,
PI1.PRODUCTNAME,
PI1.PRODUCTCODE,
PI1.SPEC,
A.UNITID,
UI.UNITNAME,
SNUM(A.DETAILID, A.SEQ) AS QUANTITY,
A.DISCOUNT,
KX_GET_FORMATNUMBER(A.UNITPRICE) UNITPRICE,
A.TAXRATE,
CASE ORDERTYPE
WHEN 'SH01' THEN
DECODE(A.PRODUCTTYPE,
'TA01',
KX_GET_FORMATNUMBER(A.PRODUCTMONEY),
0)
ELSE
KX_GET_FORMATNUMBER(A.PRODUCTMONEY)
END AS PRODUCTMONEY,
A.TAXMONEY,
KX_GET_FORMATNUMBER(A.PAYABLEMONEY) PAYABLEMONEY,
A.ISGIVEAWAY,
A.DETAILID AS COLGUID,
A.PARENTGUID,
A.ORDERID AS VGBEL,
A.SEQ AS VGPOS,
A.ORDERID AS RELEVANCEORDER,
A.MEMO,
A.CHARG,
O.STOREID,
O.SERVICEP,
O.MEMO AS ORDERMEMO,
O.PAYTYPE,
O.TOTALMONEY,
KX_GET_FORMATNUMBER(PI2.SALEPRICE) AS INITUNITPRICE,
A.SEQ,
A.QUANTITY AS ORDERQUANTITY,
(SELECT P.TEXTVALUE
FROM DATAPARAMETER P
WHERE P.CODE = A.PRODUCTTYPE
AND P.PARAMETERTYPE = 'ProductType') AS PRODUCTTYPE,
--KX_GET_DO_COUNT(a.PRODUCTID, a.UNITID, a.SURPLUSQUANTITY) as OutQuantity1,
FUN_HASORDER(A.PRODUCTID,
A.ORDERID,
'XXX',
A.UNITID,
A.SEQ) AS OUTQUANTITY
FROM SALEORDERDETAIL A
LEFT JOIN SALEORDER O
ON A.ORDERID = O.ORDERID
LEFT JOIN CUSTOMERINFO C
ON C.CUSTOMERID = O.CUSTOMERID
LEFT JOIN PRODUCTINFO PI1
ON A.PRODUCTID = PI1.PRODUCTID
LEFT JOIN PRODUCTPRICE PI2
ON A.PRODUCTID = PI2.PRODUCTID
AND PI2.UNITID = A.UNITID
AND PI2.CUSTOMERTYPE2 = C.CUSTOMERTYPE2
LEFT JOIN UNITINFO UI
ON A.UNITID = UI.UNITID
WHERE A.ORDERID = IN_ORDER_ID
AND A.CLOSEDESC = ''
AND A.STATUS <> 'C'
ORDER BY A.SEQ ASC;
KX_HISTORY_LOG(IN_ORDER_ID, '', '订单'||IN_ORDER_ID||'转交货', 'M');
END;
Oracle存储过程使用总结的更多相关文章
- oracle 存储过程
来自:http://www.jb51.net/article/31805.htm Oracle存储过程基本语法 存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 I ...
- Oracle存储过程语法
原文链接:http://www.jb51.net/article/31805.htm Oracle存储过程基本语法 存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 ...
- ORACLE存储过程调用Web Service
1. 概述 最近在ESB项目中,客户在各个系统之间的服务调用大多都是在oracle存储过程中进行的,本文就oracle存储过程调用web service来进行说明.其他主流数据库,比如mysql和sq ...
- Oracle存储过程基本语法介绍
Oracle存储过程基本语法 存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 IS 3 BEGIN 4 NULL; 5 END; 行1: CREATE OR RE ...
- MyBatis调用Oracle存储过程
MyBatis调用Oracle存储过程 1.无输入和输出参数的存储过程 2.带有输入和输出参数的存储过程 3.返回游标的存储过程 mybatis中的配置文件代码 <resultMap type= ...
- Oracle存储过程(转)
Oracle存储过程基本语法 存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 IS 3 BEGIN 4 NULL; 5 END; 行1: CREATE OR RE ...
- Oracle存储过程中异常Exception的捕捉和处理
Oracle存储过程中异常的捕捉和处理 CREATE OR REPLACE Procedure Proc_error_process ( v_IN in Varchar2, v_OUT Out Var ...
- Oracle存储过程动态创建临时表/存储过程执行权限问题--AUTHID CURRENT_USER
关于Oracle存储过程执行权限问题的解决 http://blog.sina.com.cn/s/blog_6ceed3280101hvlo.html (2014-04-02 04:06:28) 转载▼ ...
- ORACLE存储过程学习
存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 IS 3 BEGIN 4 NULL; 5 END; 行1: CREATE OR REPLACE PROCEDURE ...
- C# 获取 oracle 存储过程的 返回值1
/// <summary> /// 返回对应表的模拟自增字段值 /// </summary> /// <param name="tablename"& ...
随机推荐
- RabbitMQ 简单了解以及使用
RabbitMQ 开发语言:Erlang – 面向并发的编程语言. AMQP:是消息队列的一个协议. mysql 是 java 写的吗?不是 那么 java 能不能访问?可以,则通过(驱动)协议;那么 ...
- Pandas排序
Pandas有两种排序方式,它们分别是 - 按标签 按实际值 下面来看看一个输出的例子. import pandas as pd import numpy as np unsorted_df=pd.D ...
- 如何让Myeclipse已经关闭掉的项目不显示出来
一.打开Package Explorer视图,在它的右上角有一个向下的三角图标. 2.点击后选择Filters,在弹出的Filter配置窗口中选中"Closed Projects" ...
- 记升级mysql后的一次故障
一.问题背景 接上级要求,某生产数据库需要实施备份:刚好漏洞扫描报告出来,mysql 版本需要升级到5.7.20,于是就未雨绸缪,先写脚本.脚本在mysql旧版本下完全可用(未升级前,mysql 为5 ...
- 【C#笔札】1 string类型(2)
4> Trim whitespace Trim 也是string的一个方法节点 C#例子如下: C#中有Trim,TrimEnd 和TrimStart三种Trim节点,其中后两者无需介绍. 如上 ...
- vue.js 1.0中用v-for遍历出的li中的@click事件在移动端无效
在vue.js使用v-for遍历出的li中的@click事件在移动端无效,在网页端可以执行,代码如下 <template> <div class="rating-secti ...
- 017——VUE中v-fo指令的使用方法
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- 原创:Javascript DI!Angular依赖注入的实现原理
DI是Angular的特色功能,而在Angular 2.0的计划中,DI将成为一个独立的模块,参见 https://github.com/angular/di.js 这意味着它也有机会被用于nodej ...
- Visual Studio 2013中用VSIX创建项目模版
我会一步一步解释: 我的一个项目里有5个工程, 我想用其中的4个去创建一个新的工具模版,我还想把他们都放到一个文件夹下面当我用这个模版创建新的工程时.注意我的初始化项目,我想把他们转换成一个模版(我不 ...
- Python中实现装饰模式的三种方式
功能目标 编写一个可以打印被装饰函数名称.执行时间.内存地址得装饰器 前置依赖包 import time import functools from decorator import decorato ...