一个问号引发的血案之程序员的职业素养(java.sql.SQLException: 无效的列索引问题)

本文分享了一次解决J2EE项目中向Oracle数据库插入数据时出现的“无效的列索引”错误的经历,通过逐步排查,最终发现是SQL语句中的问号使用了中文字符。

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

    第一次做j2ee的项目,连接oracle数据库,在向数据库中插入一条数据的时候,总是不成功,每次都会报错。

 

    错误:

 

 

    晕菜的我从昨天下午就开始调试找出现这样bug的原因在哪里。。。又搭上今天一天,把可能出现问题的地方挨

个的遍历,终于在别人的帮助下找到了错误的所在。。。从中发现自己存在的问题。

 

    调试错误的过程(自己大概的总结一下):

 

    1、无论遇到什么错误,一定要先从宏观上知道这个bug所在的流程。

 

    比如这个bug 无效的列索引,首先这是在添加用户这个小模块中出现的错误,而这个过程是从界面上获取用户

输入的数据,把获取的数据打包成一个实体,将数据传递到dao层,dao再解包给专门的数据库对象

PreparedStatement来执行添加到oracle数据库中。

 

    2、对每个流程进行检查(局部检查)。

 

    A是否从界面取到了数据?

 

    首先检查是否从见面取到数据了,用户数据是否被封装到实体中了。在这过程中,要进行调试了,myeclipse中

的调试和VS中的调试大同小异,双击设置断点,F5进入方法中,F6逐语句调试,F7跳出方法,F8直接执行。在这里是

看看是否取到了界面的数据,检查中发现user实体类已经取到了界面中的数据,说明错误不在这里。

 

    Bsql语句的错误?

 

    按照vs的界面中插入表中一条数据,首先把这条sql语句在数据库中插入实验,看我们写的这条sql语句是否正

确。在这里我们用的oracle数据库,一个很好的工具,Toad能自动生成sql语句,我们直接复制粘贴就ok了。就这样

把这个sql语句写到了代码中,只不过第一次看到这种形式的:

 

    因为sql是复制过来的,并且在PL/SQL中反复的测试,是可以插入的,说明sql没有问题。

 

    可是错误提示仍然提示同样的错误,并提示在这行出现的错误: pstmt.setString(1,user.getUserId());

 

 

    C我开始猜想,是PreparedStatement的错误?(问题促进学习)

    于是上网上百度了关于PreparedStatement对象,但没有错误,数据类型也一致,从实体类中的数据类型到PreparedStatement对象设置的数据类型(setString)都保持一致,究竟问题出现在哪里呢?我开始抓狂了。。

 

 

    3、去网上查看类似的错误,百度或google等

 

    去网上查找了这样的错误,也有类似的回答。但我并没有认为网上的问题和我的问题是吻合的,并且不相信我

查找到所谓的“答案”能帮我解决这样的问题。就是这样的心态,致使我再一次与正确的答案失之交臂。胡乱的百度

谷歌,简单大概的看了看人家前人给的答案:

    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   ?;

    如ps.setString(“%”+value+“%”);

 

    没有再次去尝试,千准万准儿的认为我的sql没有任何问题。。。

 

    D于是又猜想我的oracle数据库有问题或PL/SQL有问题。。。。。

 

    最终是让别人帮我看了看,才找到问题的答案。问题就在我一准儿认为没有错误的sql语句这了,插入表中一条

数据的sql语句:insert into t_user(USER_ID,USER_NAME,PASSWORD,CONTACT_TEL,EMAIL,CREATE_DATE) values

(?,?,?,?,?,?)   我的问号是中文的!!!

 

    我怎么就没有按照找到的答案再次的仔细认真的去看sql语句呢?我怎么就不相信,不去尝试网上的答案呢?还

是没有去否定自己.......

 

    想想这个错误,我们可以在开始的时候就可以避免的。。。

 

 

    4、程序员的职业素养:

    作为一名职业的程序员,要养成良好的习惯,明知道搜狗输入法中,可以有选项避免在写注释和代码切换的时

候,输入中文的英文字符,可是没有设置。

 

 

 

 

              在做系统的时候,我们良好的习惯能让我们避免很多的错误,比如代码的命名规范问题,注释问题,详细与否?

过一年半载的再看以前的代码,你是否还能懂自己当时的想法?换另一个人来看你的代码别人能否懂?是否能只根据

文档就能开发出一个系统?一个问题你的理解和别人的理解一致否?你是否能清晰通俗的把一个技术表达出来?让自

己明白的同时让别人能明白?点滴的积累和改变中.......

 

    原来在于?和代码打交道,总避免不了会犯些小错误,有些错误既然能预测出现这样,就应该防患于未

然。想法设法的把一些预先想到的错误杀死在摇篮中的。。。。。。就像不确定的天气,我们有确定的伞,晴天遮

阳,雨天遮雨,防患于未然,照顾好自己。。。照顾好代码。。。加油!

 

 

   

 

 

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值