java.sql.SQLException: 无效的列索引其实是个低级的错误,原因无非几个:
-
1、sql串的?号数目和提供的变量数目不一致:
例如:
jdbcTemplate.update(sql, new Object[] {newState,oldState})
如果
sql
里面有1个?
号,Object[]
送了2个,就会报错。 -
2、sql串里的?号书写不正确
英文
?
和中文?
有时难以区分。 -
3、sql串的?号用’'括了起来。
例如:
sql="UPDATE abc SET abc.name='?' WHERE abc.id='?'"
把
''
去掉就可以了。 -
4、遇到这种情况
select*from user where info like %?%
虽然这是sql的写法,但是在jdbc 中需要改成
select*from user where info like ?
如:
(“%” + value + “%”)