Column specified more than once in the INSERT list.

本文详细解析了在使用Informix数据库进行数据插入操作时遇到的Column specified more than once in the INSERT list错误,并提供了相应的解决办法。

java.sql.SQLException: Column specified more than once in the INSERT list.
 at com.informix.util.IfxErrMsg.getSQLException(IfxErrMsg.java:373)
 at com.informix.jdbc.IfxSqli.a(IfxSqli.java:3208)
 at com.informix.jdbc.IfxSqli.E(IfxSqli.java:3518)
 at com.informix.jdbc.IfxSqli.dispatchMsg(IfxSqli.java:2353)
 at com.informix.jdbc.IfxSqli.receiveMessage(IfxSqli.java:2269)
 at com.informix.jdbc.IfxSqli.executePrepare(IfxSqli.java:1153)
 at com.informix.jdbc.IfxPreparedStatement.e(IfxPreparedStatement.java:318)
 at com.informix.jdbc.IfxPreparedStatement.a(IfxPreparedStatement.java:298)
 at com.informix.jdbc.IfxPreparedStatement.<init>(IfxPreparedStatement.java:168)
 at com.informix.jdbc.IfxSqliConnect.h(IfxSqliConnect.java:5909)
 at com.informix.jdbc.IfxSqliConnect.prepareStatement(IfxSqliConnect.java:1991)
 at app.batch.BatchDao.insertLninfo(BatchDao.java:780)
 at app.batch.BatchBO.getLninfoData(BatchBO.java:36)
 at app.batch.batch_in.main(batch_in.java:17)

 

错误方式:

 

写insert语句时Column重复.

SQL Server 错误信息 'invalid_pkg' has more columns than were specified in the column list. (8158) 通常意味着在定义的表值构造函数里,返回的列数超过了指定的列数。出现此错误,往往是因为在子查询或者表值表达式中,列的数量和实际使用时指定的列数量不匹配。 对于之前提供的示例代码: ```sql SELECT bfl.Handler, bfl.Lot_No, COUNT(bfl.PKG_ID) FROM [QS_Management].[dbo].[BinSort_Fail_Log] bfl WHERE bfl.StartDate >= '2025-12-14' AND bfl.StartDate <= '2025-12-16' AND NOT EXISTS ( SELECT 1 FROM (VALUES ('', 'ERROR')) AS invalid_pkg(pkg) WHERE invalid_pkg.pkg = bfl.PKG_ID ) GROUP BY bfl.Handler, bfl.Lot_No ORDER BY bfl.Handler; ``` 这里的 `(VALUES ('', 'ERROR')) AS invalid_pkg(pkg)` 定义了一个名为 `invalid_pkg` 的表值表达式,指定了一个列 `pkg`,但 `VALUES` 列表中有两个值,列数就超出了指定的列数,从而引发错误。 解决办法如下: 若只想用一个 `PKG_ID` 列表来排除特定的值,应确保 `VALUES` 列表中的列数和指定的列数一致。以下是修正后的代码: ```sql SELECT bfl.Handler, bfl.Lot_No, COUNT(bfl.PKG_ID) FROM [QS_Management].[dbo].[BinSort_Fail_Log] bfl WHERE bfl.StartDate >= '2025-12-14' AND bfl.StartDate <= '2025-12-16' AND NOT EXISTS ( SELECT 1 FROM (VALUES ('') , ('ERROR')) AS invalid_pkg(pkg) WHERE invalid_pkg.pkg = bfl.PKG_ID ) GROUP BY bfl.Handler, bfl.Lot_No ORDER BY bfl.Handler; ``` 在修正后的代码中,`(VALUES ('') , ('ERROR')) AS invalid_pkg(pkg)` 正确地把每个值列为单独的行,保证了 `VALUES` 列表中的列数和指定的列数一致。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值