1.首先要清楚JFinal提供了Db+Record的模式,而其中有一个方法是这样的Db.execute(ICallback),。
2.ICallback是JFinal提供的调用存储过程的接口,接口中提供了run方法,用来实现存储过程的调用。
简单描述代码过程
(1)我在service类中写了一个内部类来实现ICallback接口,并写了一个方法调用内部类。
(2)我写的borrow为mysql的存储过程名,其中有两个参数,两个返回值
(3)reason,result为返回值。
(4).引用包应该如下,注意是java.sql.CallableStatement和java.sql.Connection
import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.SQLException;
import com.jfinal.plugin.activerecord.Db;
import com.jfinal.plugin.activerecord.DbKit;
import com.jfinal.plugin.activerecord.ICallback;
(5)示例代码如下:
public class BorrowService{
//内部类开始
class BorrowDbPro implements ICallback {
public String oid = null;
public String reader_id=null;
int result;
public String reason="数据库意外,请重试";
public void run(Connection conn) throws SQLException {
CallableStatement proc = null;
try {
proc = (CallableStatement) conn.prepareCall("{ call borrow(?,?,?,?) }"); // borrow为mysql的存储过程名,其中有两个参数,两个返回值
proc.setString(1, oid);//设置参数值
proc.setString(2, reader_id);
proc.registerOutParameter(3, java.sql.Types.INTEGER);//设置返回值类型
proc.registerOutParameter(4, java.sql.Types.VARCHAR);
proc.execute();
result = proc.getInt(3);//得到返回值
reason=proc.getString(4);
}catch(Exception e){
e.printStackTrace();
} finally {
DbKit.close(proc, conn);
}
}
}
//内部类结束
//调用内部类方法
public void trackresult(String reader_id){//可以加参数
BorrowDbPro borrowDbPro =new BorrowDbPro();
borrowDbPro.reader_id=reader_id;
Db.execute(borrowDbPro);
String reason=borrowDbPro.reason;
}
}