1 在开发的时候发现一个问题,EntityBean 在执行插入操作的时候发现 hql生成的sql多插入了几个字段,导致Oracle报错。第一步进行调试发现EntityBean确实多了几个属性出来,去检查EntityBean 发现他继承了一个BaseEntity,而BaseEntity里面确实注解了几个属性,这几个属性对应的column在表中的字段根本没有,遂去掉继承BaseEntity编译好再次打包。依然发现还是有着几个字段,JAD反编译下,发现确实没有继承BaseEntity啊。难道tomcat 问题。第二部:清理tomcat 的temp和work,重新启动,接着继续remoting debug,但是问题依然存在,还是多了几个BaseEntity的属性。这次是彻底的郁闷了,难道是其他项目的影响,干脆tomcat 只保留这个项目,其他的全部删除。
这时问题的根源慢慢揭开了,原因:其他项目无法删除,这个时候才发现编译的class文件放错了地方,实际上放到了恰其他项目中,这样的问题如果在程序上追根溯源,根本是气死人。很多看似弱智的问题,其实很多人都有过发生。
2 我们初步开发的时候在调试程序对数据库的操作,可能是调试完了,没报错然后去数据库中看看到底插入了没有,插入的数据对不对,这次发现问题如下:tomcat 显示执行insert操作了啊 而且没有报错(程序当然做异常处理了),这下郁闷了,hibernate无误的只想了操作,数据却没有插入进来,这是为何?过程中我找我的领导,领导看了一会儿突然问我,“你查询的是哪个库的?” 我顿时醒悟了,查到另外一个库了,程序确实没错,确实插入到数据库了。那个真的想打自己。