可恶的逗号

今天在修改报表的相关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 的数据库驱动却不识别这样的语句了。汗,,,太大意了。记录下来防止再次犯错,呵呵。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值