與過程一樣,您也可以在數據庫中創建函數并將其存儲。
語法
以下是在(MySQL)數據庫中創建函數的語法:
語法
以下是在(MySQL)數據庫中創建函數的語法: p>
CREATE FUNCTION Function_Name(input_arguments) RETURNS output_parameter BEGIN declare variables; statements . . . . . . . . . . return data_type; END
登錄后復制
示例
假設數據庫中有一個名為Emp的表,其內容如下:
+--------+------------+----------------+ | Name | DOB | Location | +--------+------------+----------------+ | Amit | 1970-01-08 | Hyderabad | | Sumith | 1970-01-08 | Vishakhapatnam | | Sudha | 1970-01-05 | Vijayawada | +--------+------------+----------------+
登錄后復制
下面給出了創建函數的示例。在這里,我們創建一個名為 getDob() 的函數,它接受員工的姓名,檢索并返回 DOB 列的值。
CREATE FUNCTION getDob(emp_name VARCHAR(50)) RETURNS DATE BEGIN declare dateOfBirth DATE; select DOB into dateOfBirth from EMP where Name = emp_name; return dateOfBirth; END
登錄后復制
使用 JDBC 調用函數
您可以像存儲過程一樣使用 CallableStatement 對象調用函數,以使用您需要的 JDBC 程序調用函數。
連接到數據庫。
創建一個 PreparedStatement 對象并向其構造函數傳遞以字符串格式調用函數。
將值設置為占位符。
執行 Callable 語句。
以下是從 JDBC 調用函數的查詢:
{? = call getDob(?)}
登錄后復制
正如您所觀察到的,查詢包含占位符 (?),就像準備好的語句和可調用語句一樣。
在上面的查詢中,第一個占位符表示函數的返回值,第二個占位符表示輸入
您需要使用 CallableStatement 接口的 registerOutParameter() 方法將表示返回值的占位符注冊為輸出參數。對于此方法,您需要傳遞一個表示占位符位置的整數值和一個表示(參數的)sql 類型的整數變量
cstmt.registerOutParameter(1, Types.DATE);
登錄后復制
使用 setString() 方法將值設置為輸入參數。 (因為 getDoc() 函數接受 VARCHAR 類型的值)。
示例
以下 JDBC 程序執行函數 getDob 并檢索結果:
import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Types;
public class CallingFunctionsUsingCallable2 {
public static void main(String args[]) throws SQLException {
//Registering the Driver
DriverManager.registerDriver(new com.mysql.jdbc.Driver());
//Getting the connection
String mysqlUrl = "jdbc:mysql://localhost/sampleDB";
Connection con = DriverManager.getConnection(mysqlUrl, "root", "password");
System.out.println("Connection established......");
//Preparing a CallableStatement
CallableStatement cstmt = con.prepareCall("{? = call getDob(?)}");
cstmt.registerOutParameter(1, Types.DATE);
cstmt.setString(2, "Amit");
cstmt.execute();
System.out.print("Date of birth: "+cstmt.getDate(1));
}
}
登錄后復制
輸出
Connection established...... Date of birth: 1970-01-08
登錄后復制
以上就是我們可以使用 Callable 語句調用函數嗎?能用 JDBC 的例子解釋一下嗎?的詳細內容,更多請關注www.92cms.cn其它相關文章!






