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(?,?,?,?) }");
- 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;
- }
- }