`
阅读更多

今天在修改报表的相关sql语句时遇到一个问题,花了我大半个小时时间

具体来源需求:系统中有几个报表现在是只统计了那些有数据影院的城市,没有订单数据的城市没有进行统计(即全部是0),目前也需要将这些数据全部显示出来。

按照需求,我修改了相关的sql(sql直接存放在表中,这样直接修改sql就可以了,不用修改相关代码,灵活性很好),然后在plsql中执行,ok,一切正常。然后将sql放到生产环境。放上去之后,我一点菜单,NND,查不到数据,我知道后台肯定报错了,刚快将原来的sql语句还原,仔细在开发数据库上进行测试,根据本地控制台报的错,网上搜了半天,都不是自己要的,找了半天,终于找到了一篇文章,地址是:http://www.blogjava.net/jlin/articles/317591.html

我才恍然大悟,赶快查看,修改,运行;果然是这个原因,痛哭流涕啊!真是恩人啊。

 

原文:

控制台抛出这个异常:java.sql.SQLException: ORA-00911: invalid character
查了一下说是oracle字符集设置的问题。我将抛异常的SQL语句在控制台输出如下:

select count(t.id) as onerowc,t.id as areatravelid ,b.id as airpotid from base_areatravel t inner join base_airpot b on b.areaid=t.id group by t.id ,b.id;

以上是完完整整的输出结果,然后我将语句复制到PL/SQL中执行是完全可以的,没有任何异常的。。

而我在程序中定义的sql如下:

String sql="select count(t.id) as onerowc,t.id as areatravelid ,b.id as airpotid from base_areatravel t"+
    " inner join base_airpot b on b.areaid=t.id group by t.id ,b.id;";

呵呵,花费了半个多小时终于找到原因::::

哈哈,,定义语句中sql后面多了一个分号。(“;”)晕菜。。这样的话在PL/SQL中是无所谓的,可是Java 的数据库驱动却不识别这样的语句了。汗,,,太大意了。记录下来防止再次犯错,呵呵。。。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics