SQL报错!!!

1. DB2 SQL Error: SQLCODE=-302, SQLSTATE=22001

1.1 具体报错

SqlMapClient operation;   
--- The error occurred in com/baosight/tbms/qg/ln/sql/QGLN18.xml.  
--- The error occurred while applying a parameter map.  
--- Check the QGLN18.update11-InlineParameterMap.  
--- Check the statement (update failed).  
--- Cause: com.ibm.db2.jcc.am.SqlDataException: DB2 SQL Error: SQLCODE=-302, SQLSTATE=22001, SQLERRMC=null, DRIVER=4.21.29;

 1.2 错误原因

        具体错误信息是:SQLCODE=-302, SQLSTATE=22001,即执行的SQL语句返回了一个数据值过大的结果,无法被正确地存储。这可能是由于数据类型不匹配或者数据长度超出限制所致。

        该案例明确提示执行 QGLN18.xml 中的 QGLN18.update11 时报错。

1.3 解决方案 

检查更新的字段的值长度及数据库中字段长度,① 给数据库字段扩容;② 删除一部分插入的数据。

 

 2. Caused by: java.sql.SQLSyntaxErrorException: ORA-00918: 未明确定义列

2.1 具体报错

Caused by: java.sql.SQLSyntaxErrorException: ORA-00918: 未明确定义列

2.2 错误原因

 通俗一点说,引起该错误的主要原因是因为select的某个字段在from的多个表中都存在,并且没有进行表名/别名约束,这个时候系统不知道应该选择哪个表中的这个字段,所以会抛出该错误。如:select name from demo1 a,demo2 b;

2.3 解决方案

 对select的字段进行表名/别名约束。如:select a.name from demo1 a,demo2 b;

  • 7
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值