JFinal调用Mysql存储过程方法

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;  
  }
}


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值