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)示例代码如下:

[java]  view plain  copy
  1. public class BorrowService{  
  2. //内部类开始  
  3. class BorrowDbPro implements ICallback {  
  4.     public String oid = null;  
  5.     public String reader_id=null;  
  6.     int result;  
  7.     public String reason="数据库意外,请重试";  
  8.     public void run(Connection conn) throws SQLException {      
  9.     CallableStatement proc = null;  
  10.            try {             
  11.    
  12.               proc = (CallableStatement) conn.prepareCall("{ call borrow(?,?,?,?) }"); // borrow为mysql的存储过程名,其中有两个参数,两个返回值  
  13.              proc.setString(1, oid);//设置参数值  
  14.              proc.setString(2, reader_id);  
  15.              proc.registerOutParameter(3, java.sql.Types.INTEGER);//设置返回值类型  
  16.              proc.registerOutParameter(4, java.sql.Types.VARCHAR);  
  17.             proc.execute();  
  18.    
  19.             result =  proc.getInt(3);//得到返回值  
  20.             reason=proc.getString(4);  
  21.       }catch(Exception e){  
  22.               e.printStackTrace();  
  23.        } finally {  
  24.             DbKit.close(proc, conn);  
  25.           }  
  26.     }  
  27.   
  28. }  
  29. //内部类结束  
  30. //调用内部类方法  
  31.   public void trackresult(String reader_id){//可以加参数  
  32.            BorrowDbPro  borrowDbPro =new BorrowDbPro();  
  33.              borrowDbPro.reader_id=reader_id;  
  34.             Db.execute(borrowDbPro);  
  35.             String reason=borrowDbPro.reason;    
  36.   }  
  37. }  
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值