.net 使用oracle 的存储过程有返回值也有数据集(游标)
public void GetData(string username, string userip, string userkey, string userareaid, string ypid, string in_provinces, string yearid, out DataTable data, out string out_success, out string out_message)
{
try
{
string constr = ConfigurationManager.ConnectionStrings["constr"].ToString();
using (OracleConnection con = new OracleConnection(constr))
{
con.Open();
OracleCommand cmd = new OracleCommand("proc_pricefind", con);
cmd.CommandType = CommandType.StoredProcedure;
OracleParameter[] paras = new OracleParameter[]
{
new OracleParameter("username", username),
new OracleParameter("userip", userip),
new OracleParameter("userkey", userkey),
new OracleParameter("userareaid", userareaid),
new OracleParameter("ypids", ypid),
new OracleParameter("in_provinces", in_provinces),
new OracleParameter("yearid", yearid),
new OracleParameter("data",OracleType.Cursor),
new OracleParameter("out_success",OracleType.VarChar,4000),
new OracleParameter("out_message",OracleType.VarChar,4000)
};
paras[paras.Length - 1].Direction = ParameterDirection.Output;
paras[paras.Length - 2].Direction = ParameterDirection.Output;
paras[paras.Length - 3].Direction = ParameterDirection.Output;
cmd.Parameters.AddRange(paras.ToArray());
OracleDataAdapter da = new OracleDataAdapter(cmd);
DataSet ds = new DataSet();
da.Fill(ds);
out_success = paras[paras.Length - 2].Value.ToString();
out_message = paras[paras.Length - 1].Value.ToString();
data = ds.Tables[0];
//如果没有返回数据集的话,可以直接使用ExecuteNonQuery()。然后取out的值,这样就不需要把OracleDataReader装换为datatable
//cmd.ExecuteNonQuery();
// out_message = paras[paras.Length - 3].Value;
//OracleDataReader odr = paras[paras.Length - 3].Value as OracleDataReader;
// data=ConvertDataReaderToDataTable(odr);
}
}
catch (Exception ex)
{
out_success = "0";
out_message = ex.Message;
data = null;
}
}
create or replace procedure proc_pricefind(username varchar,
userip varchar,
userkey varchar,
userareaid varchar,
ypids varchar,
in_provinces varchar,
yearid varchar,
data out sys_refcursor,
out_success out varchar,
out_message out varchar) is
findcount number;
configcount number;
findareaidcount number;
configareacount number;
guid varchar(36);
begin
out_success := '0';
out_message := '';
select sys_guid() into guid from dual;
insert into findprice_userrecord
(recordid,
usernmae,
userip,
userkey,
userareaid,
ypid,
findareaid,
yearid,
addtime)
values
(guid,
username,
userip,
userkey,
userareaid,
ypids,
in_provinces,
yearid,
sysdate);
commit;
insert into findprice_log_userrecord
select guid,
sys_guid(),
b.产品名称,
b.剂型分类名称,
b.规格,
b.转换系数,
b.材质,
b.企业名,
t.purprice
from mid_monthspurprice t
inner join view_drug a
on a.sdid = t.sdid
inner join base_stddrug b
on a.sdcode = b.原流水码
where substr(t.dr, 0, 4) = yearid
and b.ypid = ypids
and t.provinceareaid = in_provinces;
commit;
--判断计算条数
select count(distinct t.ypid ||','|| t.findareaid||','|| t.yearid) kk
into findcount
from findprice_userrecord t
where t.userareaid = userareaid;
select t.findnumber
into configcount
from findprice_config t
where t.areaid = userareaid;
if findcount > configcount then
delete from findprice_userrecord t where t.recordid = guid;
delete from findprice_log_userrecord t where t.recordid = guid;
commit;
--删除插入进去的数据
raise_application_error(-20000, '查询的总条数超过了限制');
end if;
--判断计算的省份
select count(1) tol
into out_success
from mon_joinpoint
where instr((select min(t.findareaid)
from findprice_config t
where t.areaid = userareaid),
provinceidnew) > 0
and provinceareaid in (in_provinces);
select count(distinct t.findareaid) tol
into findareaidcount
from findprice_userrecord t
where t.userareaid = userareaid;
if out_success = 0 and findareaidcount > 10 then
delete from findprice_userrecord t where t.recordid = guid;
delete from findprice_log_userrecord t where t.recordid = guid;
commit;
raise_application_error(-20000, '查询省份超过了限制' || configcount);
end if;
open data for
select ypids,
b.产品名称,
b.剂型分类名称,
b.规格,
b.转换系数,
b.材质,
b.企业名,
t.purprice
from mid_monthspurprice t
inner join view_drug a
on a.sdid = t.sdid
inner join base_stddrug b
on a.sdcode = b.原流水码
where substr(t.dr, 0, 4) = yearid
and b.ypid = ypids
and t.provinceareaid = in_provinces;
out_success:='1';
end proc_pricefind;
如果给存储过程加了获取异常的脚本
EXCEPTION
WHEN OTHERS THEN
那么需要在
data out sys_refcursor, 返回的类型顺便赋一些值,不然在.net中执行存储过程会报错如下: open data for
select '0' from dual;
最简单的
create or replace procedure proc_relpage(pageindex number,
data out sys_refcursor) is
begin
open data for
select *
from rel_stdzdrugtemp20160204 a
) );
end proc_relpage;
.net 使用oracle 的存储过程有返回值也有数据集(游标)的更多相关文章
- oracle 写存储过程有返回值时 注意在loop循环处添加返回值:=
例子: create or replace procedure p_xl is v_count NUMBER(10); begin for rs in(select yhbh from dbyh) l ...
- oracle存储过程(返回列表的存储结合游标使用)总结 以及在java中的调用
这段时间开始学习写存储过程,主要原因还是因为工作需要吧,本来以为很简单的,但几经挫折,豪气消磨殆尽,但总算搞通了,为了避免后来者少走弯路,特记述与此,同时亦对自己进行鼓励. 以下是我在开发项目中第一次 ...
- C#获取执行存储过程的" 返回值"代码
以下是C#代码: /// <summary> /// 执行存储过程,返回" 返回值" /// </summary> /// <param name=& ...
- SqlServer如何获取存储过程的返回值
1.Output参数返回值 1 CREATE PROCEDURE [dbo].[upInformation]( 2 @age int , 3 @id bigint OUTPUT 4 ) 5 AS 6 ...
- 利用SQLServer查询分析器获取存储过程的返回值,检查测试存储过程
1.存储过程没有返回值的情况(即存储过程语句中没有return之类的语句)用方法 int count = ExecuteNonQuery(..)执行存储过程其返回值只有两种情况(1)如果通过查询分析器 ...
- 在Delphi中如何获得SQL中存储过程的返回值?
示例存储过程:create procedure proc_loginusername varchar(20),password varchar(20)asdeclare @result intsele ...
- .net 接收存储过程的返回值 。。。。
.net 接收存储过程的返回值 .... Posted on 2009-06-10 20:26 且行且思 阅读(...) 评论(...) 编辑 收藏 例如在向数据库添加新数据时,需要检测是否有重复 本 ...
- 关于ExecuteNonQuery执行存储过程的返回值 、、实例讲解存储过程的返回值与传出参数、、、C#获取存储过程的 Return返回值和Output输出参数值
关于ExecuteNonQuery执行存储过程的返回值 用到过ExecuteNonQuery()函数的朋友们在开发的时候肯定这么用过. if(cmd.ExecuteNonQuery("xxx ...
- JDBC和JPA调用储存过程 接收存储过程有返回值
============jdbc==========================================--java代码:一个输出参数--String connURL = null;Con ...
随机推荐
- linux防火墙,高级策略策略实例详解(实例一)
双线服务器的控制问题: 要求:写出这个电信用户访问到双线web服务器时的IP变化过程(只写源IP,目标IP,和做SNAT还是DNAT等) 你觉得有没有问题? 实验环境: 精简一点可以使用下面的四台虚拟 ...
- UOJ176 新年的繁荣
题目链接 Boruvka生成树算法 \(Boruvka\)算法就是先把每个点看作一个联通块,然后不断在联通块之间找最优的边进行合并.因为每次联通块的数量最少缩小一半.所以合并次数是\(log\)的 先 ...
- Summary of Java basics review data
1.标识符 用于命名程序的对象,如方法名,变量名,规则是: a.大小写敏感 b.由英文字符,文字字符,美元符号,下划线和数字组成,但不能以数字开头 c.不能是关键字 2.%:求余运算符 ...
- 如何测试连接MsSQL数据库-------UDL文件
http://www.xinnet.com/service/cjwt/idc/sjk/1360.html 如果您所使用的 SQL Server 数据库连不上,可以通过这个方法进行测试数据库连接. 温馨 ...
- PostCSS理解与运用
1.PostCSS是什么 它可以被理解为一个平台,可以让一些插件在上面跑 它提供了一个解析器,可以将CSS解析成抽象语法树 通过PostCSS这个平台,我们能够开发一些插件,来处理CSS.热门插件如a ...
- 一个很适合初学者的selenium教程
http://www.cnblogs.com/hustar0102/p/5885115.html
- python学习笔记--文件重命名,删除及文件夹
文件重命名 import os os.rename('123.txt','456.txt') 删除文件 >>> import os >>> os.remove('4 ...
- 【强大的视频编辑工具】Adobe Premiere Pro CC 2019 for Mac
[简介] PR CC是视频编辑爱好者和专业人士必不可少的视频编辑工具.它可以提升您的创作能力和创作自由度,它是易学.高效.精确的视频剪辑软件.PR CC提供了采集.剪辑.调色.美化音频.字幕添加.输出 ...
- Mesos初体验-Mesos优势
一.Mesos优势 1.Mesos的核心是分布式集群资源分配,不负责任务调度,因而Mesos可以和其他集群协同工作 2.Mesos主要实现了分布式集群的管理系统中的资源分配功能,其他功能主要靠额外的组 ...
- bzoj2733 离线+并查集+主席树
https://www.lydsy.com/JudgeOnline/problem.php?id=2733 网上清一色的合并线段树题解,我又不会,只能自己胡来,没想到Rush过去了 永无乡包含 n 座 ...