根据sqlId获取Ibatis配置文件中的SQL


import com.ibatis.sqlmap.engine.impl.SqlMapClientImpl;
import com.ibatis.sqlmap.engine.mapping.sql.Sql;
import com.ibatis.sqlmap.engine.scope.SessionScope;
import com.ibatis.sqlmap.engine.scope.StatementScope;
import com.ibatis.sqlmap.engine.mapping.statement.MappedStatement;
/**
* 获取SQL
* ibatais根据sqlMap的Id获取sql语句
* @param sqlId 是xml文件配置的ID
* @return sql语句 以“$”注入的会自动转换,“#”不会
*/
public static String getSql(SqlMapClientImpl sqlclientImpl,String sqlId,Object params){

String sqlStr = "";
/**获取隐身对象*/
MappedStatement stmt = sqlclientImpl.getMappedStatement(sqlId);
Sql sql = stmt.getSql();
/**获取规则*/
SessionScope sessionScope = new SessionScope();
sessionScope.incrementRequestStackDepth();
StatementScope statementScope = new StatementScope(sessionScope);
stmt.initRequest(statementScope);
/**获取sql映射对象*/
sqlStr = sql.getSql(statementScope, params);

log.debug("sqlMap:"+sqlId);
log.debug("sql:"+sqlStr);

return sqlStr;
}



以上便是获取sql语句的方法。
[b]也许有些地方看不明了,在这里增加一点点解释。[/b]
传参:
[b]SqlMapClientImpl[/b] 就是指的我们平时使用的 SqlMapClient 当然在传这个参数需要强制类型转换 如: SqlMapClientImpl temp = (SqlMapClientImpl)sqlMapClient;
[b]String sqlId [/b]指的 就是 我Ibatais.sqlMap.xml中定义的SQL的Id
[b] Object params [/b]这个参数指的是sqlMap.xml中 如<insert parameterClass="params">..</insert>的parameterClass传入的对象,如果没有可以为null。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值