.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 ...
随机推荐
- springboot jar包运行中获取资源文件
1. 今天晚上写了一个程序,基于Spring boot的一个小网站,发现使用FileUtils.class.getResource(path)来获取jar包中的资源文件并不能成功,其路径很奇怪 fil ...
- ORACLE报错和解决方案
ORA-01034: ORACLE not available ORA-27101 出现ORA-01034和ORA-27101的原因是多方面的:主要是oracle当前的服务不可用,shared mem ...
- pre标签内文本自动换行
pre标签内文本自动换行 给pre标签添加一个css样式 pre { white-space: pre-wrap; /* css-3 */ white-space: -moz-pre-wrap; /* ...
- jquery 追加元素/jquery文档处理,插入、修改、移动、删除指定的DOM元素.
jquery 追加元素 $("#content").append("..."); // 添加到元素内部最后面 $("#content").p ...
- 前端JS Excel解析导入
本文转载自:https://www.cnblogs.com/yinqingvip/p/6743213.html 需要用到js-xlsx:下载地址:js-xlsx <!DOCTYPE html&g ...
- sha256加密
sha256: 1.使用npm安装 :npm install js-sha256 2.然后在组件中methods定义方法,在调用 // sha256加密密码 setSha(){ let sha256 ...
- poj1637 Sightseeing tour(混合图欧拉回路)
题目链接 题意 给出一个混合图(有无向边,也有有向边),问能否通过确定无向边的方向,使得该图形成欧拉回路. 思路 这是一道混合图欧拉回路的模板题. 一张图要满足有欧拉回路,必须满足每个点的度数为偶数. ...
- 通过锁字符串达到控制并发的效果C#
lock锁的是地址 而.net有内部机制使得相同的字符串内存地址是相同的(new string)除外 下面上实验代码 using System; using System.Collections.Ge ...
- (转)深入理解Java注解类型(@Annotation)
背景:在面试时候问过关于注解的问题,工作中也用到过该java的特性,但是也没有深入的了解. 秒懂,Java 注解 (Annotation)你可以这样学 ps:注解最通俗易懂的解释 注解是一系列元数据, ...
- 解决plink报错:.bim file has a split chromosome. Use --make-bed by itself to remedy this.
由于plink1.9和1.07这两个版本互掐,经常出现各种不兼容问题,“.bim file has a split chromosome. Use --make-bed by itself to r ...