sql 报:无效的列索引 可能的原因

作者遇到SQL报无效的列索引错误,网上多认为是拼写错误。作者移除注释后问题解决,还列举了其他可能的拼写错误,如占位符与参数数量不一致、SQL拼接错误、错误的注释等,提醒遇到此类错误要仔细检查SQL语句。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

https://blog.youkuaiyun.com/aaronmer/article/details/82256369

今天遇到了sql报无效的列索引错误,在网上找了找问题,基本都在说是sql拼写错误,

基本可以确定这个错误一般都是由低级失误导致的,请注意检查自己的sql拼写

按照网上指出的问题去找,没有和自己错误一样的,最后在移除一个注释后正常了,

我用的是idea,用ctrl+/ 加的注释 ,也就是sql前加  --,

不知为何没有生效,却成了错误源头,

在此记录下防止自己忘记,另外其他几种可能的拼写错误如下

1.占位符与参数数量不一致

例如当有一个占位符?,但是再此处传入两个参数#{a},#{b},

2.sql拼接错误

如对于模糊查询条件 a的拼接

a like '%'||#{a}||'%' 

注意每个%都要用 '' 包括起来  ,与参数用 || 拼接

当然也可以这样写 a like  CONCAT(CONCAT('%', #{a}), '%')

3.错误的注释

这就是我遇到的情况了,我把不用的sql通过 --注释掉,

但是注释却没有正常生效,导致无效的列索引出现,删掉后就好了

当然也可能有其他原因导致这种情况

 

总之遇到这样的错误 自习检查SQl语句是否拼写正确尤其是标点符号问号占位符,是否给参数两边留有空格,是否参数外面没有单引号或双引号引起。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值