亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? java

?? 世界知名IT公司的JAVA面試題
??
字號:
學生在學習jdbc的時候,會問到怎么調(diào)用存儲過程,現(xiàn)在將java調(diào)用oracle存儲過程的示例總結(jié)如下。(關(guān)于調(diào)用sqlserver的存儲過程將在下次進行小結(jié)請關(guān)注)

一:無返回值的存儲過程

存儲過程為:

? create or replace procedure adddept(deptno number,dname varchar2,loc varchar2)

? as

? begin

? insert into dept values(deptno,dname,loc);

? end;

然后呢,在java里調(diào)用時就用下面的代碼:

? public class TestProcedure {

? Connection conn=null ;

? CallableStatement cstmt=null ;

? PreparedStatement pstmt=null ;

? String url="jdbc:oracle:thin:@localhost:1521:mydb";

? String driver="oracle.jdbc.driver.OracleDriver";

? String name="";

? public TestProcedure() {

? try {

? Class.forName(driver);

? conn=DriverManager.getConnection(url,"scott","tiger");

? cstmt=conn.prepareCall("{call adddept(?,?,?)}");

? cstmt.setInt(1,13);

? cstmt.setString(2,"間諜部2");

? cstmt.setString(3,"ningbo2");

 cstmt.executeUpdate(); 

? 

? System.out.println("success");

? }

? catch (Exception e){e.printStackTrace();}

? finally{

? cstmt.close();

? conn.close();

? }

? }

? }

dept表為oracle數(shù)據(jù)庫方案scott中的一個表

二:有返回值的存儲過程(非列表)

存儲過程為:

CREATE OR REPLACE PROCEDURE TESTB(PARA1 IN VARCHAR2,PARA2 OUT VARCHAR2) AS

BEGIN 

SELECT INTO PARA2 FROM TESTTB WHERE I_ID= PARA1; 

END TESTB;

在java里調(diào)用時就用下面的代碼:

package com.hyq.src;


public class TestProcedureTWO {

public TestProcedureTWO() {

}

public static void main(String[] args ){

String driver = "oracle.jdbc.driver.OracleDriver";

String strUrl = "jdbc:oracle:thin:@127.0.0.1:1521:hyq";

Statement stmt = null;

ResultSet rs = null;

Connection conn = null;

try {

Class.forName(driver);

conn = DriverManager.getConnection(strUrl, " hyq ", " hyq ");

CallableStatement proc = null;

proc = conn.prepareCall("{ call HYQ.TESTB(?,?) }");

proc.setString(1, "100");

proc.registerOutParameter(2, Types.VARCHAR);

proc.execute();

String testPrint = proc.getString(2);

System.out.println("=testPrint=is="+testPrint);

}

catch (SQLException ex2) {

ex2.printStackTrace();

}

catch (Exception ex2) {

ex2.printStackTrace();

}

finally{

try {

if(rs != null){

rs.close();

if(stmt!=null){

stmt.close();

}

if(conn!=null){

conn.close();

}

}

}

catch (SQLException ex1) {

}

}

}

}


}

注意,這里的proc.getString(2)中的數(shù)值2并非任意的,而是和存儲過程中的out列對應(yīng)的,如果out是在第一個位置,那就是proc.getString(1),如果是第三個位置,就是proc.getString(3),當然也可以同時有多個返回值,那就是再多加幾個out參數(shù)了。

三:返回列表

由于oracle存儲過程沒有返回值,它的所有返回值都是通過out參數(shù)來替代的,列表同樣也不例外,但由于是集合,所以不能用一般的參數(shù),必須要用pagkage了.所以要分兩部分,

1, 建一個程序包。如下:

CREATE OR REPLACE PACKAGE TESTPACKAGE AS

TYPE Test_CURSOR IS REF CURSOR;

end TESTPACKAGE;

2,建立存儲過程,存儲過程為:

CREATE OR REPLACE PROCEDURE TESTC(p_CURSOR out TESTPACKAGE.Test_CURSOR) IS 

BEGIN

OPEN p_CURSOR FOR SELECT * FROM HYQ.TESTTB;

END TESTC;

可以看到,它是把游標(可以理解為一個指針),作為一個out 參數(shù)來返回值的。

在java里調(diào)用時就用下面的代碼:

package com.hyq.src;

import java.sql.*;

import java.io.OutputStream;

import java.io.Writer;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import oracle.jdbc.driver.*;



public class TestProcedureTHREE {

public TestProcedureTHREE() {

}

public static void main(String[] args ){

String driver = "oracle.jdbc.driver.OracleDriver";

String strUrl = "jdbc:oracle:thin:@127.0.0.1:1521:hyq";

Statement stmt = null;

ResultSet rs = null;

Connection conn = null;


try {

Class.forName(driver);

conn = DriverManager.getConnection(strUrl, "hyq", "hyq");


CallableStatement proc = null;

proc = conn.prepareCall("{ call hyq.testc(?) }");

proc.registerOutParameter(1,oracle.jdbc.OracleTypes.CURSOR);

proc.execute();

rs = (ResultSet)proc.getObject(1);


while(rs.next())

{

System.out.println("<tr><td>" + rs.getString(1) + "</td><td>"+rs.getString(2)+"</td></tr>");

}

}

catch (SQLException ex2) {

ex2.printStackTrace();

}

catch (Exception ex2) {

ex2.printStackTrace();

}

finally{

try {

if(rs != null){

rs.close();

if(stmt!=null){

stmt.close();

}

if(conn!=null){

conn.close();

}

}

}

catch (SQLException ex1) {

}

}

}

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91在线视频18| 免费成人在线观看视频| 91麻豆swag| 亚洲图片激情小说| 91久久精品一区二区三| 亚洲精品乱码久久久久久| 欧洲av在线精品| 丝袜美腿高跟呻吟高潮一区| 欧美一区二区三区系列电影| 狠狠色丁香九九婷婷综合五月| 久久久久久久久97黄色工厂| 国产成人av资源| 亚洲精品国产a久久久久久 | 国产精品18久久久| 亚洲国产精品激情在线观看| 色婷婷综合在线| 亚洲成a人在线观看| 精品成a人在线观看| 不卡免费追剧大全电视剧网站| 亚洲精品日日夜夜| 欧美一级二级三级蜜桃| 国产精品一区二区你懂的| 一区二区三区欧美日韩| 7777精品久久久大香线蕉| 国产成人在线网站| 亚洲大型综合色站| 国产午夜精品美女毛片视频| 欧洲国产伦久久久久久久| 韩国精品主播一区二区在线观看 | 欧美艳星brazzers| 毛片不卡一区二区| 国产精品久久久久婷婷| 欧美日韩色一区| 国产盗摄视频一区二区三区| 三级欧美在线一区| 91啪九色porn原创视频在线观看| 久久综合丝袜日本网| |精品福利一区二区三区| 日本aⅴ精品一区二区三区 | 亚洲色图丝袜美腿| 日韩欧美123| 色综合久久久网| 国产一区激情在线| 亚洲成人1区2区| 中文字幕第一区二区| 69p69国产精品| 91年精品国产| 国产宾馆实践打屁股91| 婷婷成人激情在线网| 亚洲精品大片www| 久久久国产午夜精品 | 九九**精品视频免费播放| 日韩伦理av电影| 精品少妇一区二区三区在线播放| 色偷偷久久人人79超碰人人澡| 国产综合久久久久久鬼色| 日本视频一区二区| 亚洲在线中文字幕| 亚洲日穴在线视频| 国产欧美久久久精品影院| 精品久久久久香蕉网| 91精品国产综合久久久久久漫画 | 欧美日韩国产在线播放网站| 97久久精品人人做人人爽50路| 久久99精品一区二区三区| 亚洲一区二区三区中文字幕| 国产精品久久久久桃色tv| 久久久久久久久久电影| 欧美精品一区二| 精品va天堂亚洲国产| 欧美草草影院在线视频| 91精品国产乱码| 91精品在线免费观看| 欧美色成人综合| 欧美午夜精品一区二区蜜桃| 91精品1区2区| 精品视频999| 欧美日韩免费电影| 欧美日韩国产一级二级| 欧美色图免费看| 欧美乱妇20p| 777奇米四色成人影色区| 欧美精品第一页| 日韩一区二区三区免费观看| 欧美α欧美αv大片| 日韩一区二区三区视频| 精品国产成人在线影院 | 在线不卡中文字幕| 69p69国产精品| 欧美va亚洲va香蕉在线| 精品88久久久久88久久久 | 欧美国产精品中文字幕| 亚洲国产高清不卡| 亚洲女子a中天字幕| 亚洲精品国产精华液| 亚洲国产精品久久久久婷婷884| 亚洲成人先锋电影| 日本免费在线视频不卡一不卡二| 日本va欧美va精品发布| 国产69精品久久久久毛片| 91色porny蝌蚪| 欧美高清hd18日本| 久久久亚洲精品一区二区三区| 国产精品毛片高清在线完整版| 亚洲猫色日本管| 日韩国产精品久久| 国产一区二区三区久久久| 成人免费视频播放| 在线看一区二区| 欧美成人三级在线| 国产精品久久国产精麻豆99网站| 一区二区理论电影在线观看| 五月天亚洲婷婷| 国产美女精品一区二区三区| 色综合网色综合| 5月丁香婷婷综合| 国产欧美视频在线观看| 亚洲一区免费观看| 国产在线一区二区| 色呦呦日韩精品| 欧美精品一区二区三区蜜桃视频| 国产精品久久久久久久久搜平片| 性欧美疯狂xxxxbbbb| 粉嫩欧美一区二区三区高清影视| 在线观看免费一区| www国产精品av| 天天综合天天综合色| 成人听书哪个软件好| 69久久夜色精品国产69蝌蚪网| 国产视频一区二区在线| 香蕉久久一区二区不卡无毒影院| 极品少妇xxxx偷拍精品少妇| 欧美视频在线播放| 国产精品久久久久影院| 精品一区二区三区香蕉蜜桃| 一本一道综合狠狠老| 久久一留热品黄| 日韩高清在线电影| 91麻豆产精品久久久久久 | ...av二区三区久久精品| 美女一区二区在线观看| 在线观看三级视频欧美| 中文字幕乱码一区二区免费| 九色综合国产一区二区三区| 欧美三片在线视频观看| 国产精品短视频| 国产成人高清在线| 精品国产91洋老外米糕| 日韩av成人高清| 欧美在线免费播放| 中文字幕亚洲视频| 成人免费av资源| 日本一二三四高清不卡| 国产成人综合精品三级| 久久精品一级爱片| 国产一区不卡视频| 337p粉嫩大胆噜噜噜噜噜91av| 琪琪久久久久日韩精品| 欧美日韩的一区二区| 亚洲小少妇裸体bbw| 91国偷自产一区二区三区成为亚洲经典 | 国产精品久久久久久久久免费桃花| 国产做a爰片久久毛片 | 亚洲国产精品国自产拍av| 久久99蜜桃精品| 日韩欧美中文一区| 免费成人结看片| 欧美精品一区二区久久久| 美女任你摸久久| 欧美成人精品高清在线播放| 琪琪一区二区三区| wwwwxxxxx欧美| 国产一区二区不卡老阿姨| 国产亚洲精久久久久久| 国产成人免费视频一区| 国产精品三级视频| 99国产精品久久久久久久久久久 | 高清在线不卡av| 中文字幕精品三区| 91免费版在线看| 亚洲图片欧美色图| 欧美精品日日鲁夜夜添| 日本不卡视频在线| 91精品国产色综合久久ai换脸| 五月婷婷激情综合| 精品欧美乱码久久久久久| 激情图片小说一区| 国产精品视频看| 色综合久久88色综合天天| 天堂av在线一区| 精品动漫一区二区三区在线观看| 久久精品免费观看| 国产精品丝袜久久久久久app| 99re这里都是精品| 午夜精品免费在线观看| 日韩欧美精品三级| jizzjizzjizz欧美| 丝袜诱惑制服诱惑色一区在线观看| 精品日本一线二线三线不卡| 国产成人免费视频精品含羞草妖精|