㈠ java裡面怎麼調用mysql的存儲過程的
java代碼:
Class.forName("com.mysql.jdbc.Driver");
Connectioncon=DriverManager
.getConnection("jdbc:mysql://localhost:3306/test?user=root&password=111111");
Stringsql="{callsel(?)}";
CallableStatementcs=(CallableStatement)con.prepareCall(sql);
cs.execute();
Stringname=cs.getString(1);
System.out.println(name);
創建存儲過程代碼:
dropprocereifexistssel;
createproceresel(outname1varchar(225))
begin
;
end
輸出結果:
㈡ java中如何調用資料庫的存儲過程
Java調用存儲過程的方法是通過調用Connection的實例方法prepareCall,prepareCall方法返回CallableStatement對象用於填充存儲過程的參數。prepareCall方法形參是調用存儲過程的sql語句,此參數的語法格式如下:
{callstoredProcereName(parameter-list)}
其中,storedProcereName是存儲過程名稱,parameter-list是存儲過程參數列表。
例如,存儲過程名為usp_test,有兩個輸入參數a,b。則調用代碼看起來如下所示:
=connection.prepareCall("{callusp_test(?,?)}");
callableStatement.setObject("a","value-1");
callableStatement.setObject("b","value-2");
callableStatement.execute();
㈢ java中如何調用帶有數組類型參數的存儲過程
java.sql
介面 Array
所有已知實現類:
SerialArray
SQL 類型 ARRAY 在 Java 編程語言中的映射關系。默認情況下,Array 值是對 SQL ARRAY 值的事務處理期引用。默認情況下,Array 對象是使用 SQL LOCATOR(array) 內部實現的,這意味著 Array 對象包含一個指向 SQL ARRAY 值中數據的邏輯指針,而不是包含 ARRAY 值的數據。
Array 介面提供了某些方法將 SQL ARRAY 值的數據作為數組或 ResultSet 對象傳送到客戶端。如果 SQL ARRAY 的元素是一個 UDT,那麼可以自定義映射它們。要創建自定義映射關系,編程人員必須做兩件事:
為將被自定義映射的 UDT 創建一個實現 SQLData 介面的類。
在類型映射表中生成一個項,該項包含
UDT 的完全限定 SQL 類型名稱
實現 SQLData 的類的 Class 對象
在將帶有對應於基本類型的項的類型映射表提供給 getArray 和 getResultSet 方法時,該表所包含的映射關系將用於映射 ARRAY 值的元素。如果沒有提供類型映射表(通常是這種情況),則默認使用連接的類型映射表。如果該連接的類型映射表或為某一方法提供的類型映射表沒有對應於基本類型的項,則根據標准映射關系來映射這些元素。
getArray()
以 Java 編程語言數組的形式檢索由此 Array 對象指定的 SQL ARRAY 值的內容。
getArray(long index, int count)
檢索由此 Array 對象指定的 SQL ARRAY 值的一部分,從指定 index 開始,包含 SQL 數組中 count 個連續元素。
getArray(long index, int count, Map<String,Class<?>> map)
檢索由此 ARRAY 對象指定的 SQL Array 值的一部分,從指定 index 開始,包含 SQL 數組中 count 個連續元素。
getArray(Map<String,Class<?>> map)
檢索由此 Array 對象指定的 SQL ARRAY 值的內容。
getBaseType()
在由此 Array 對象指定的數組中檢索元素的 JDBC 類型。
getBaseTypeName()
在由此 Array 對象指定的數組中檢索元素的 SQL 類型名稱。
getResultSet()
檢索包含此 Array 對象指定的 SQL ARRAY 值的元素的結果集合。
getResultSet(long index, int count)
檢索保存子數組的元素的結果集合,從索引 index 開始,包含 count 個連續元素。
getResultSet(long index, int count, Map<String,Class<?>> map)
檢索保存子數組的元素的結果集合,從索引 index 開始,包含 count 個連續元素。
getResultSet(Map<String,Class<?>> map)
檢索包含由此 Array 對象指定的 SQL ARRAY 值的元素的結果集合。