首頁 資料庫 mysql教程 oracle存储过程一(返回单条记录的值)

oracle存储过程一(返回单条记录的值)

Jun 07, 2016 pm 03:38 PM
oracle 使用 儲存 記錄 過程 返回

最近在使用java验证excel表单元的信息,数据量非常大,而且验证的规则比较复杂,如果单纯使用程序的验证的话,效率将非常低,考虑到oracle存储过程是可编译的,每次编译之后都会将数据放入高速缓存当中,下次再取,速度将非常的快。之前并没有接触到oracle的

最近在使用java验证excel表单元格的信息,数据量非常大,而且验证的规则比较复杂,如果单纯使用程序的验证的话,效率将非常低,考虑到oracle存储过程是可编译的,每次编译之后都会将数据放入高速缓存当中,下次再取,速度将非常的快。之前并没有接触到oracle的存储过程,所以也花了几天的时间去研究了一番,由于时间紧迫,没有怎么很好的整理。现在先将比较基本的一些实现方法给大家分享一下

  下面是使用java调用存储过程来返回out的值,因为存储过程有三种参数,in表输入,out表输出,in out即可输入又可输出,什么意思呢?刚接触的人可能就不大明白了,其实in就像java方法中的参数一样,可将参数传到存储过程(其实就将存储过程看成方法就行了,只是比较特殊,他是可编译的),而out相当于java方法的返回参数,只是存储过程可以定义多个out,相当于可以return多个参数一样,do you understand?

  需要注意的是,out可以返回单条记录或者多条记录,他们的实现方法是不一样的,返回单条记录直接将他作为某个变量赋值就行,下面随便写了一个例子说明一下:

存储过程代码:

oracle存储过程一(返回单条记录的值)

<p>CREATE OR REPLACE PROCEDURE pro_return_result
(
  a in varchar2,b out varchar2
) AS 
  BEGIN
    if a is not null then
      b := '不好说';
    end if;
  END pro_return_result;</p>
登入後複製

oracle存储过程一(返回单条记录的值)

java调用代码:(只贴出核心部分,其他的数据库连接自己搞定)

oracle存储过程一(返回单条记录的值)

oracle存储过程一(返回单条记录的值)代码

<p>CallableStatement cs  = null;
        cs  = con.prepareCall("{call pro_return_result(?,?)}");
        cs.setString(1, "1");
        cs.registerOutParameter(2, Types.VARCHAR);
        cs.execute();
        String result = cs.getString(2);
        System.out.println(result);</p>
登入後複製

oracle存储过程一(返回单条记录的值)

看到上面的例子了吧,因为存储过程第二个参数是out输入,并且是返回单条记录的,所以使用这样的一个方法对输出out进行注册
cs.registerOutParameter(2, Types.VARCHAR);
输出结果:不好说
如果要输出多个记录,则在存储过程写多几个out,然后写多几个cs.registerOutParameter(参数位置, Types.VARCHAR);OK搞定返回单条记录

如果存储过程要为默写变量赋值,返回单条记录时,可使用这样的一种方式:select 某表的字段1,字段2…… into 变量1,变量2 from 表 where 表字段=某个值
如例子:<p></p><p><span><img  src="/static/imghw/default1.png" data-src="/inc/test.jsp?url=http%3A%2F%2Fcommon.cnblogs.com%2Fimages%2Fcopycode.gif&refer=http%3A%2F%2Fblog.csdn.net%2Fzajin%2Farticle%2Fdetails%2F9335997" class="lazy" alt="oracle存储过程一(返回单条记录的值)" ></span></p><img  src="/static/imghw/default1.png" data-src="/inc/test.jsp?url=http%3A%2F%2Fimages.cnblogs.com%2FOutliningIndicators%2FExpandedBlockStart.gif&refer=http%3A%2F%2Fblog.csdn.net%2Fzajin%2Farticle%2Fdetails%2F9335997" class="lazy" alt="oracle存储过程一(返回单条记录的值)" ><span>代码</span><p></p><pre class="brush:php;toolbar:false"><p>CREATE OR REPLACE PROCEDURE validate_module_name
(
  a in varchar2,b out varchar2
) AS 
c varchar2(255);
BEGIN
  select module_one into c
  from temp_test_case where num= a;
  
    if c is not null then
      b := '1';
    end if;
END validate_module_name;</p>
登入後複製

oracle存储过程一(返回单条记录的值)


调用的方式和上面说的一样,as下是放自定义的变量,begin到End是PL/SQL语句,PL/SQL中的空值使用is null来表示,非空为:is not null,这和java程序有所区别,PL/SQL有时间再详解

注:存储过程还有一种返回情况,返回的是多条记录,既结果集,而不是单条记录,则不能使用上面的那种方法,得使用游标输出结果集,同时select 某表的字段1,字段2……
into 变量1,变量2 from 表 where 表字段=某个值这种方式也不能使用,因为select into语句只使用返回单条记录的情况。在java调用存储过程也不能使用
cs.registerOutParameter(参数位置, Types.VARCHAR)了,存储过程返回结果集的java调用下回详解……
登入後複製
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

oracle中計算兩個日期之間天數的函數 oracle中計算兩個日期之間天數的函數 May 08, 2024 pm 07:45 PM

oracle中計算兩個日期之間天數的函數

oracle資料庫日誌會保存多久 oracle資料庫日誌會保存多久 May 10, 2024 am 03:27 AM

oracle資料庫日誌會保存多久

oracle資料庫啟動步驟順序為 oracle資料庫啟動步驟順序為 May 10, 2024 am 01:48 AM

oracle資料庫啟動步驟順序為

oracle中interval的用法 oracle中interval的用法 May 08, 2024 pm 07:54 PM

oracle中interval的用法

oracle中某個字元出現的次數怎麼看出來 oracle中某個字元出現的次數怎麼看出來 May 09, 2024 pm 09:33 PM

oracle中某個字元出現的次數怎麼看出來

oracle資料庫伺服器硬體配置需求 oracle資料庫伺服器硬體配置需求 May 10, 2024 am 04:00 AM

oracle資料庫伺服器硬體配置需求

oracle需要多少內存 oracle需要多少內存 May 10, 2024 am 04:12 AM

oracle需要多少內存

oracle中替換字串的方法 oracle中替換字串的方法 May 08, 2024 pm 07:24 PM

oracle中替換字串的方法

See all articles