java調(diào)用sqlserver的存儲(chǔ)過(guò)程詳解

java調(diào)用sqlserver的存儲(chǔ)過(guò)程詳解

ID:34723867

大小:84.68 KB

頁(yè)數(shù):8頁(yè)

時(shí)間:2019-03-10

java調(diào)用sqlserver的存儲(chǔ)過(guò)程詳解_第1頁(yè)
java調(diào)用sqlserver的存儲(chǔ)過(guò)程詳解_第2頁(yè)
java調(diào)用sqlserver的存儲(chǔ)過(guò)程詳解_第3頁(yè)
java調(diào)用sqlserver的存儲(chǔ)過(guò)程詳解_第4頁(yè)
java調(diào)用sqlserver的存儲(chǔ)過(guò)程詳解_第5頁(yè)
資源描述:

《java調(diào)用sqlserver的存儲(chǔ)過(guò)程詳解》由會(huì)員上傳分享,免費(fèi)在線(xiàn)閱讀,更多相關(guān)內(nèi)容在工程資料-天天文庫(kù)。

1、Java調(diào)用SQLServer的存儲(chǔ)過(guò)程詳解2012-05-1500:00中國(guó)IT實(shí)驗(yàn)室佚名.關(guān)鍵字:Java  1使用不帶參數(shù)的存儲(chǔ)過(guò)程  1  {callprocedure-name}  作為實(shí)例,在SQLServer2005AdventureWorks示例數(shù)據(jù)庫(kù)中創(chuàng)建以下存儲(chǔ)過(guò)程:  CREATEPROCEDUREGetContactFormalNames  ASBEGINSELECTTOP10Title+''+FirstName+''+LastNameASFormalName  FROMPerson.ContactEND  此存儲(chǔ)過(guò)程返回單個(gè)結(jié)果集,其中包含一列數(shù)據(jù)(由Person.

2、Contact表中前十個(gè)聯(lián)系人的稱(chēng)呼、名稱(chēng)和姓氏組成)。  在下面的實(shí)例中,將向此函數(shù)傳遞AdventureWorks示例數(shù)據(jù)庫(kù)的打開(kāi)連接,然后使用executeQuery方法調(diào)用GetContactFormalNames存儲(chǔ)過(guò)程。  publicstaticvoidexecuteSprocNoParams(Connectioncon)  …{  try…{  Statementstmt=con.createStatement();  ResultSetrs=stmt.executeQuery("{calldbo.GetContactFormalNames}");  while(rs.nex

3、t())  …{  System.out.println(rs.getString("FormalName"));  }  rs.close();  stmt.close();  }  catch(Exceptione)  …{  e.printStackTrace();  }  }  2使用帶有輸入?yún)?shù)的存儲(chǔ)過(guò)程  使用JDBC驅(qū)動(dòng)程序調(diào)用帶參數(shù)的存儲(chǔ)過(guò)程時(shí),必須結(jié)合SQLServerConnection類(lèi)的prepareCall方法使用callSQL轉(zhuǎn)義序列。帶有IN參數(shù)的call轉(zhuǎn)義序列的語(yǔ)法如下所示:  {callprocedure-name[([parameter][,[param

4、eter]]…)]}  構(gòu)造call轉(zhuǎn)義序列時(shí),請(qǐng)使用?(問(wèn)號(hào))字符來(lái)指定IN參數(shù)。此字符充當(dāng)要傳遞給該存儲(chǔ)過(guò)程的參數(shù)值的占位符??梢允褂肧QLServerPreparedStatement類(lèi)的setter方法之一為參數(shù)指定值??墒褂玫膕etter方法由IN參數(shù)的數(shù)據(jù)類(lèi)型決定?! ∠騭etter方法傳遞值時(shí),不僅需要指定要在參數(shù)中使用的實(shí)際值,還必須指定參數(shù)在存儲(chǔ)過(guò)程中的序數(shù)位置。例如,如果存儲(chǔ)過(guò)程包含單個(gè)IN參數(shù),則其序數(shù)值為1.如果存儲(chǔ)過(guò)程包含兩個(gè)參數(shù),則第一個(gè)序數(shù)值為1,第二個(gè)序數(shù)值為2.  作為如何調(diào)用包含IN參數(shù)的存儲(chǔ)過(guò)程的實(shí)例,使用SQLServer2005AdventureWo

5、rks示例數(shù)據(jù)庫(kù)中的uspGetEmployeeManagers存儲(chǔ)過(guò)程。此存儲(chǔ)過(guò)程接受名為EmployeeID的單個(gè)輸入?yún)?shù)(它是一個(gè)整數(shù)值),然后基于指定的EmployeeID返回雇員及其經(jīng)理的遞歸列表。下面是調(diào)用此存儲(chǔ)過(guò)程的Java代碼:  publicstaticvoidexecuteSprocInParams(Connectioncon)  …{  try…{  PreparedStatementpstmt=con.prepareStatement("{calldbo.uspGetEmployeeManagers(?)}");  pstmt.setInt(1,50);  Resul

6、tSetrs=pstmt.executeQuery();  while(rs.next())  …{  System.out.println("EMPLOYEE:");  System.out.println(rs.getString("LastName")+","+rs.getString("FirstName"));  System.out.println("MANAGER:");  System.out.println(rs.getString("ManagerLastName")+","+rs.getString("ManagerFirstName"));  System.out.p

7、rintln();  }  rs.close();  pstmt.close();  }  catch(Exceptione)  …{  e.printStackTrace();  }  }  3使用帶有輸出參數(shù)的存儲(chǔ)過(guò)程  使用JDBC驅(qū)動(dòng)程序調(diào)用此類(lèi)存儲(chǔ)過(guò)程時(shí),必須結(jié)合SQLServerConnection類(lèi)的prepareCall方法使用callSQL轉(zhuǎn)義序列。帶有OUT參數(shù)的call轉(zhuǎn)義序列的語(yǔ)法如下

當(dāng)前文檔最多預(yù)覽五頁(yè),下載文檔查看全文

此文檔下載收益歸作者所有

當(dāng)前文檔最多預(yù)覽五頁(yè),下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學(xué)公式或PPT動(dòng)畫(huà)的文件,查看預(yù)覽時(shí)可能會(huì)顯示錯(cuò)亂或異常,文件下載后無(wú)此問(wèn)題,請(qǐng)放心下載。
2. 本文檔由用戶(hù)上傳,版權(quán)歸屬用戶(hù),天天文庫(kù)負(fù)責(zé)整理代發(fā)布。如果您對(duì)本文檔版權(quán)有爭(zhēng)議請(qǐng)及時(shí)聯(lián)系客服。
3. 下載前請(qǐng)仔細(xì)閱讀文檔內(nèi)容,確認(rèn)文檔內(nèi)容符合您的需求后進(jìn)行下載,若出現(xiàn)內(nèi)容與標(biāo)題不符可向本站投訴處理。
4. 下載文檔時(shí)可能由于網(wǎng)絡(luò)波動(dòng)等原因無(wú)法下載或下載錯(cuò)誤,付費(fèi)完成后未能成功下載的用戶(hù)請(qǐng)聯(lián)系客服處理。