.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 ...
随机推荐
- 牛客网Wannafly挑战赛25A 因子(数论 素因子分解)
链接:https://www.nowcoder.com/acm/contest/197/A来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言5242 ...
- servlet 上下文
一.应用需求: 如何统计网站在线人数? 使用ServletContext. 二.ServletContext详解: 1.是不同于session和cookie,是可以让所有客户端共同访问的内容,是在服务 ...
- Spring Boot 与 OAuth2 官方最详细教程
https://mp.weixin.qq.com/s?__biz=MzU0MDEwMjgwNA==&mid=2247484357&idx=1&sn=73e501de8591e6 ...
- react-native实现电影列表
页面运行效果 代码: import React, { Component } from "react"; import { Image, FlatList, StyleSheet, ...
- JMeter关联(正则表达式提取器)
正则表达式总结 关联:与系统交互过程中,系统返回的内容,需要在接下来的交互中用到,如防止csrf攻击而生成的token. 从前一个请求中取,用Regular Expression Extractor ...
- linux系统调用之文件系统操作
access 确定文件的可存取性 chdir 改变当前工作目录 fchdir 参见chdir chmod 改变文件方式 fchmod 参见chmod chown 改变文件的属主或用户组 fchown ...
- Day24--Python--常用模块03--正则表达式
正则表达式是对字符串操作的⼀种逻辑公式. 我们⼀般使⽤正则表达式对字符串进⾏匹配和过滤. 使⽤正则的优缺点: 优点: 灵活, 功能性强, 逻辑性强. 缺点: 上⼿难. ⼀旦上⼿, 会爱上这个东⻄ ⼯具 ...
- vue 本地存储数据 sessionStorage
在vuex 下的 action下的userAction.js中添加 export function login(from, self) { axPost('/api/login', from, fun ...
- 2018年度最优秀mac软件及游戏推荐,个个万里挑一
今天和大家带来2018年度最优秀Mac软件和游戏合集,个个万里挑一,2018年,风云社区(scoee.com)分享了上数千款优秀的Mac软件和游戏,结合用户反馈,精选出各个类别的优秀的Mac软件,推荐 ...
- Kubernetes 集群ca验证
创建集群时跳过ca验证 # vim /etc/kubernetes/apiserver 去除KUBE_ADMISSION_CONTROL中的 SecurityContextDeny,ServiceAc ...