java 动态生成sql_Java获取Mybatis动态生成的sql

前提:已经编写好相应的接口个xml文件

publicvoid exportExcel_bw() throws Exception {

//封装sql需要查询的sql的条件

Map paramMap = new HashMap();

paramMap.put("parentName", "权限管理");

paramMap.put("pageBegin", 0);

paramMap.put("pageSize", 20);

//获取执行sql

Configuration con = sqlSessionFactory.getConfiguration();

//传xml文件中的 需要执行的id编号 如下图说明

MappedStatement s = con.getMappedStatement(com.sgd.eic.nxdb.yhqd.dao.YhqdSuspectEleStealDao.selectSuspectUserEleStealStat);

BoundSql bSql = s.getBoundSql(paramMap);

//获取到sql中封装的参数的数量

List paramValues = bSql.getParameterMappings();

String sql=getExecuteSql(bSql.getSql(),paramValues,paramMap);

//创建连接

SqlSession session = sqlSessionFactory.openSession();

Statement cs = session.getConnection().createStatement();

ResultSet set = cs.executeQuery(sql);//执行查询

System.out.println(sql);

}

/**

* 生成可执行sql

* @param sql 获取的sql

* @param paramValues 动态参key

* @param map 动态参valur

* @return

*/

private String getExecuteSql(String sql, List paramValues,Map map) {

while(sql.indexOf("?") != -1 && paramValues.size() > 0) {

String paramName = paramValues.get(0).getProperty();

String paramValue = map.get(paramName).toString();

String value = "";

if (paramValue instanceof String) {

value = "'" + paramValue + "'";

}

sql = sql.replaceFirst("\\?", value);

paramValues.remove(0);

}

return sql;

}

1933797a6a6a72808b7c8fae34f62b1b.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值