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 的存储过程有返回值也有数据集(游标)的更多相关文章

  1. oracle 写存储过程有返回值时 注意在loop循环处添加返回值:=

    例子: create or replace procedure p_xl is v_count NUMBER(10); begin for rs in(select yhbh from dbyh) l ...

  2. oracle存储过程(返回列表的存储结合游标使用)总结 以及在java中的调用

    这段时间开始学习写存储过程,主要原因还是因为工作需要吧,本来以为很简单的,但几经挫折,豪气消磨殆尽,但总算搞通了,为了避免后来者少走弯路,特记述与此,同时亦对自己进行鼓励. 以下是我在开发项目中第一次 ...

  3. C#获取执行存储过程的" 返回值"代码

    以下是C#代码: /// <summary> /// 执行存储过程,返回" 返回值" /// </summary> /// <param name=& ...

  4. SqlServer如何获取存储过程的返回值

    1.Output参数返回值 1 CREATE PROCEDURE [dbo].[upInformation]( 2 @age int , 3 @id bigint OUTPUT 4 ) 5 AS 6 ...

  5. 利用SQLServer查询分析器获取存储过程的返回值,检查测试存储过程

    1.存储过程没有返回值的情况(即存储过程语句中没有return之类的语句)用方法 int count = ExecuteNonQuery(..)执行存储过程其返回值只有两种情况(1)如果通过查询分析器 ...

  6. 在Delphi中如何获得SQL中存储过程的返回值?

    示例存储过程:create procedure proc_loginusername varchar(20),password varchar(20)asdeclare @result intsele ...

  7. .net 接收存储过程的返回值 。。。。

    .net 接收存储过程的返回值 .... Posted on 2009-06-10 20:26 且行且思 阅读(...) 评论(...) 编辑 收藏 例如在向数据库添加新数据时,需要检测是否有重复 本 ...

  8. 关于ExecuteNonQuery执行存储过程的返回值 、、实例讲解存储过程的返回值与传出参数、、、C#获取存储过程的 Return返回值和Output输出参数值

    关于ExecuteNonQuery执行存储过程的返回值 用到过ExecuteNonQuery()函数的朋友们在开发的时候肯定这么用过. if(cmd.ExecuteNonQuery("xxx ...

  9. JDBC和JPA调用储存过程 接收存储过程有返回值

    ============jdbc==========================================--java代码:一个输出参数--String connURL = null;Con ...

随机推荐

  1. linux防火墙,高级策略策略实例详解(实例一)

    双线服务器的控制问题: 要求:写出这个电信用户访问到双线web服务器时的IP变化过程(只写源IP,目标IP,和做SNAT还是DNAT等) 你觉得有没有问题? 实验环境: 精简一点可以使用下面的四台虚拟 ...

  2. UOJ176 新年的繁荣

    题目链接 Boruvka生成树算法 \(Boruvka\)算法就是先把每个点看作一个联通块,然后不断在联通块之间找最优的边进行合并.因为每次联通块的数量最少缩小一半.所以合并次数是\(log\)的 先 ...

  3. Summary of Java basics review data

    1.标识符      用于命名程序的对象,如方法名,变量名,规则是: a.大小写敏感 b.由英文字符,文字字符,美元符号,下划线和数字组成,但不能以数字开头 c.不能是关键字 2.%:求余运算符    ...

  4. 如何测试连接MsSQL数据库-------UDL文件

    http://www.xinnet.com/service/cjwt/idc/sjk/1360.html 如果您所使用的 SQL Server 数据库连不上,可以通过这个方法进行测试数据库连接. 温馨 ...

  5. PostCSS理解与运用

    1.PostCSS是什么 它可以被理解为一个平台,可以让一些插件在上面跑 它提供了一个解析器,可以将CSS解析成抽象语法树 通过PostCSS这个平台,我们能够开发一些插件,来处理CSS.热门插件如a ...

  6. 一个很适合初学者的selenium教程

    http://www.cnblogs.com/hustar0102/p/5885115.html

  7. python学习笔记--文件重命名,删除及文件夹

    文件重命名 import os os.rename('123.txt','456.txt') 删除文件 >>> import os >>> os.remove('4 ...

  8. 【强大的视频编辑工具】Adobe Premiere Pro CC 2019 for Mac

    [简介] PR CC是视频编辑爱好者和专业人士必不可少的视频编辑工具.它可以提升您的创作能力和创作自由度,它是易学.高效.精确的视频剪辑软件.PR CC提供了采集.剪辑.调色.美化音频.字幕添加.输出 ...

  9. Mesos初体验-Mesos优势

    一.Mesos优势 1.Mesos的核心是分布式集群资源分配,不负责任务调度,因而Mesos可以和其他集群协同工作 2.Mesos主要实现了分布式集群的管理系统中的资源分配功能,其他功能主要靠额外的组 ...

  10. bzoj2733 离线+并查集+主席树

    https://www.lydsy.com/JudgeOnline/problem.php?id=2733 网上清一色的合并线段树题解,我又不会,只能自己胡来,没想到Rush过去了 永无乡包含 n 座 ...