Callable Statements能否调用函数?用JDBC示例解释一下?
类似于存储过程,您也可以在数据库中创建函数并存储它们。
阅读更多:MySQL 教程
语法
以下是在(MySQL)数据库中创建函数的语法:
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(?)}
正如您所观察到的,查询中包含与预准备和可调用语句一样占位符(?)。
在上面的查询中,第一个占位符表示函数的返回值,第二个占位符表示输入参数。
您需要使用 registerOutParameter() 方法(CallableStatement接口的方法)将代表返回值的占位符注册为输出参数。对于该方法,需要传递表示占位符位置的整数值,以及表示参数的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 {
//注册驱动程序
DriverManager.registerDriver(new com.mysql.jdbc.Driver());
//获取连接
String mysqlUrl = "jdbc:mysql://localhost/sampleDB";
Connection con = DriverManager.getConnection(mysqlUrl, "root", "password");
System.out.println("Connection established......");
//准备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));
}
}
输出
连接已建立......
生日:1970-01-08
极客教程