公司的公元前代码底层DB2有这么一段代码。
SQL:
StringBuffer sql = new StringBuffer("select userdetails.details_date details_date ,
userdetails.POLICYCODE POLICYCODE, userdetails.ordercode ordercode ,userdetails.plan_name
plan_name ,userdetails.integral integral,userdetails.status status ,
userdetails.details_desc details_desc ,userdetails.person_name USER_NAME
from GE_USER_INTEGRALDETAILS userdetails ");
userdetails.person_name 的别名 USER_NAME
ResultSetMetaData md = rs.getMetaData();
int length = md.getColumnCount();
while(rs.next()){
hm = new IndexMap();
for(int i = 0; i < length; i++){
String ColName = md.getColumnName(i+1);
hm.put(ColName, rs.getString(ColName));
}
result.add(hm);
}
这么一看没什么问题,其实里面埋着巨坑。。。
因为业务的发展,要搬到新的数据库,tomcat/lib 下面有 db2jcc.jar,db2jcc_license_cu.jar,db2jcc4.jar
(其实包括tomcat7,程序代码,jar ,JDK6.0 都没变,只是电脑的内存,硬盘,JJ, 比以前更大了)
但新服务器tomcat启动后,偏偏就是加载了db2jcc4.jar, 而IBM提供的db2jcc4.jar数据库驱动程序使用了JDBC 4.0,导致结果集映射的规则不同于3.0版本,从而导致找不到列的错误。
com.sinosoft.common.DBAccess 2016-12-12 00:02:15,747-- ERROR -- DBAccess执行sql语句时出错,
sql=select userdetails.details_date details_date ,userdetails.POLICYCODE POLICYCODE,
userdetails.ordercode ordercode ,userdetails.plan_name plan_name ,
userdetails.integral integral,userdetails.status status ,userdetails.details_desc details_desc ,
userdetails.person_name USER_NAME from GE_USER_INTEGRALDETAILS userdetails
where userdetails.details_type = ? and userdetails.customerid = ?
order by details_date desc fetch first 100 rows only ,
参数=com.ibm.db2.jcc.am.SqlException: [jcc][10150][10300][4.17.29]
参数无效:未知列名 PERSON_NAME。 ERRORCODE=-4460, SQL
原来结果集返回了 USER_NAME 的列名,而 md.getColumnName(i+1) 因为是4.0的关系返回的是表的列名而不是结果集的列名,而根据3.0版本,应该返回的是结果集的列名。
至于为什么会加载db2jcc4.jar,也是迷一样,在本地local跑,根据排序都是先加载db2jcc.jar,然后不加载db2jcc4.jar。
这里先记之,只能先解决问题:tomcat/lib 下去掉db2jcc4.jar。
参考资料:http://ghoulich.xninja.org/2016/01/29/solve-error-code-4460-in-db2/
最后奉上错误日志:
com.sinosoft.common.DBAccess 2016-12-12 00:02:15,745-- ERROR -- listArrEle2Str error
java.lang.ClassCastException: java.lang.String cannot be cast to [Ljava.lang.String;
at com.sinosoft.common.DBAccess.listArrEle2Str(DBAccess.java:559)
at com.sinosoft.common.DBAcces