DB2获取表名或别名发生参数无效:未知列名 PERSON_NAME。 ERRORCODE=-4460,

在将代码从旧数据库迁移到新服务器时,遇到一个问题:由于新服务器的Tomcat加载了db2jcc4.jar(JDBC 4.0驱动),导致获取表名或别名时出现错误,具体为'PERSON_NAME'列名未找到(ERRORCODE=-4460)。原来JDBC 4.0的驱动返回的是表的列名,而非结果集的列名,与之前的3.0版本行为不同。解决方案是删除lib目录下的db2jcc4.jar,确保使用旧版本驱动。参考链接提供了更多解决细节。
摘要由CSDN通过智能技术生成

公司的公元前代码底层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
### 回答1: db2 errorcode=-4229是指在执行SQL语句时发生了死锁(Deadlock)错误。这种错误通常是由于多个事务同时请求相同的资源而导致的。为了解决这个问题,可以通过重新设计事务或者增加资源来避免死锁的发生。同时,也可以通过使用DB2的锁定机制来避免死锁的发生。 ### 回答2: db2 errorcode=-4229是一种数据库错误代码,通常与db2数据库服务器的连接相关的问题有关。当用户无法成功连接到db2数据库服务器时,数据库服务器会返回这个错误代码。 通常错误码-4229可能是由于以下原因引起的: 1.连接被拒绝:在db2数据库中,通常会出现许多不同的错误导致拒绝连接,在此情况下,错误码-4229可能是由于连接帐户密码错误或无法识别的连接源所致。 2. db2数据库服务器没有启动或处于宕机状态:db2数据库服务器可能无法运行或处于宕机状态,这可能导致无法连接到数据库服务器,从而生成错误码-4229。 3. 数据库协议错误:db2数据库可能需要使用特定的日期格式或其他协议才能与客户端成功通信。如果客户端使用的协议与db2服务器不匹配,则可能会发生错误码-4229。 4. 数据库启用了安全机制:在db2数据库中,可能需要对客户端进行身份验证以授权访问。如果客户端无法成功通过身份验证,则连接将被拒绝并且生成错误码-4229。 以上是造成db2 errorcode=-4229的主要原因,用户在遇到此错误码时应该验证连接帐户密码、检查数据库服务器是否启动、确保协议匹配或与管理员联系获取进一步支持。 ### 回答3: DB2错误码-4229是一种数据库错误。发生此类错误时,DB2无法识别一个或多个SQL语句或命令。这种错误的常见原因是数据库不兼容或错误的SQL语句及语法错误。 解决DB2错误码-4229需要以下步骤: 第一步是检查SQL语句是否正确。如果有语法问题,则需要修复该语句以使其适用于数据库。这通常涉及到使用正确的关键词、拼写单词正确、正确的语句顺序及将语句与正确的数据类型配对。 第二步是检查数据库是否与应用程序兼容。如果应用程序使用的数据库数据库不兼容,则会导致此类型的错误。这可以通过检查数据库的版本、兼容性与应用程序的要求来确定。 第三步是检查数据库日志和错误日志以确定出错的具体原因。这可以帮助确定问题的根本原因。 第四步是查看DB2文档以了解该错误码的详细细节及其解决方案。这可以为您提供其他建议和正确的操作来解决错误。 最后,如果您无法解决DB2错误-4229,请与您的开发团队、数据库管理员或DB2支持服务联系,以帮助诊断和解决问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值