今天用jdbc preparestatement 写sql语句查询,但是在执行的过程中实际查询出的结果和预期的结果不一致,然后就在想有什么办法能够在控制台或者Log4j日志输出最终执行的SQL语句,以便于调试。如果是hibernate可以通过配置show_sql 为 true 在控制台显示执行的SQL,因为使用的是纯JDBC的写法,然后自己在程序中直接通过System.out.println(sql);打印SQL语句,然后又打印参数,这种方式确实是可以。但是,遇到insert语句或者Update语句的时候,因为实际操作中需要传入的匹配参数有点多,然后通过System.out.println()这种方式写的就有点多了,十几个参数就需要写十几行,然后就在想,能不能通过什么方式进行简化一下。。。
/**
* 显示SQL语句
* @param sql
* @param paramMap
*/
public static void show_sql(Logger log,String sql,List<String> paramList){
log.info("##sql:{}",sql);
log.info("##参数:{}",JSONArray.fromObject(paramList));
/*if(null != paramList && paramList.size() > 0){
for (int i = 0; i < paramList.size(); i++) {
log.info(""+i+" : "+paramList.get(i));
}
}*/
}
最原始的方法,直接一个一个取:
//输出SQL语句
paramList.add(officeUserInfo.getUsername());
paramList.add(officeUserInfo.getPassword