像过程一样,您也可以在数据库中创建函数并将其存储。
以下是在(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
您可以像存储过程一样使用CallableStatement对象调用函数,以使用所需的JDBC程序调用函数。
连接到数据库。
创建一个PreparedStatement对象,并向其构造函数传递String格式的函数调用。
为占位符设置值。
执行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 { //注册驱动程序 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)); } }
Connection established...... Date of birth: 1970-01-08