浏览 6501 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2007-12-11
昨天跟了一下代码,从getSqlMapClientTemplate一路跟到ibatis的源代码, 找到了几处关键性代码,因此提取出来,在jpetstore上试验了一下,发现可行, 所以和大家分享一下. import com.ibatis.sqlmap.engine.impl.ExtendedSqlMapClient; import com.ibatis.sqlmap.engine.impl.SqlMapExecutorDelegate; import com.ibatis.sqlmap.engine.mapping.sql.Sql; import com.ibatis.sqlmap.engine.mapping.statement.MappedStatement; //SqlMapExecutorDelegate是一个相当核心的类,他存放了配置文件所有信息和java连接对象,有一个会话池和一个请求池,还有sql解析其,以及一个具体sql语句的执行者,大家可以看看 SqlMapExecutorDelegate delegate=((ExtendedSqlMapClient)(getSqlMapClientTemplate().getSqlMapClient())).getDelegate(); //这个类用来存放某个id名的Statement信息,如这个当中的getProduct就是一条语句的配置id名 MappedStatement ms = delegate.getMappedStatement("getProduct"); //sql类就是某一类型 Statement的对应sql拼装解析类 Sql sql=ms.getSql(); //然后调用getSql方法,把参数值数组传进去,如下面只有一个参数productId,便可以生成 形如 select * from xxx where xx=?的sql语句了,代理类的sql执行者便可以根据这个sql和参数值数组进行参数查询了,前面那个参数的类型是com.ibatis.sqlmap.engine.scope.RequestScope,这个要从上面提到的代理类里面获取,但是因为是保护成员,而且发现拼凑sql的时候并没有多大作用,所以传了个null进去,结果居然通过了,不过这部分我还要确认一下.个人感觉RequestScope还是很重要的,可以会影响其他类型的Statement System.out.println(sql.getSql(null,productId) ); 以上例子代码是改自JPetstore, 建议大家自己重写一个继承自SqlMapClientDaoSupport的抽象类,把这个提取sql功能写成一个基类方法,好让具体的业务dao类使用. 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2007-12-12
在Log中输出SQL语句的代码,供参考
SqlMapClientTemplate sqlMapClientTemplate = super .getSqlMapClientTemplate(); SqlMapClientImpl sqlMapClientImpl = (SqlMapClientImpl) sqlMapClientTemplate .getSqlMapClient(); MappedStatement mappedStatement = sqlMapClientImpl .getMappedStatement(statementName); Sql sql = mappedStatement.getSql(); RequestScope requestScope = new RequestScope(); mappedStatement.initRequest(requestScope); String sqlString = sql.getSql(requestScope, parameterObject); ParameterMap parameterMap = sql.getParameterMap(requestScope, parameterObject); requestScope.setParameterMap(parameterMap); Object[] parameterArr = parameterMap.getParameterObjectValues( requestScope, parameterObject); |
|
返回顶楼 | |
发表时间:2008-09-17
请参考http://blog.csdn.net/key232323/archive/2007/11/01/1862165.aspx
|
|
返回顶楼 | |