今天在修改报表的相关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 的数据库驱动却不识别这样的语句了。汗,,,太大意了。记录下来防止再次犯错,呵呵。。。
分享到:
相关推荐
SQL截取以逗号分隔的字符串SQL截取以逗号分隔的字符串SQL截取以逗号分隔的字符串SQL截取以逗号分隔的字符串
把表单内用户输入的中文逗号即全角字符转换为英文逗号即半角符号,需要使用客户端脚本语言javascript来实现,请看下面的代码:
加逗号工具
逗号替换成回车逗号
可以快速将字符串转化为大小写、加引号和逗号便于查询 可以快速将字符串转化为大小写、加引号和逗号便于查询
SQLServer逗号分隔的字符串转换成表
oracle查询表的所有列并用逗号隔开
TXT数据去除逗号
逗号表达式(表达式1,表达式2….)逗号表达式最右边的值为逗号表达式的值.one
txt文件读取以逗号为分隔符号 txt文件读取以逗号为分隔符号
主要介绍了js下将金额数字每三位一逗号分隔的相关资料,还附加了一个小功能,小数位保留两位,感兴趣的小伙伴们可以参考一下
采用正则表达式 代码简洁,测试过 js 金额数字的逗号显示
使用C#读取TXT文档中的内容,将逗号去除保留其他内容,其他格式均不发生变化
目的:毕达哥拉斯逗号是一种古希腊的音乐数学调音方法,它定义了两个频率和一个虚拟频率的指数耦合常数谐波定律的整数比。 逗号表示易于观察并可以进行数学模拟的物理谐波系统。 虚拟谐波是必不可少的,可以间接测量...
oracle 关于字符串中带有逗号间隔的查询 例如 我想查出dwdh中有“飞信”的内容(不包括移动飞信,飞信移动) 关于字符串中带有逗号间隔的查询 利用like
在做项目时,经常会遇到这样的表结构在主表的中有一列保存的是用逗号隔开ID
JS字符串添加删除操作,以逗号分隔.可自定义分隔符,但不支持正则特殊字符。
js控制文本框只能输入正整数和逗号,且检查字符是否是数字
易语言使用正则取逗号个数源码,使用正则取逗号个数
字符串中的逗号间隔识别出来.这样就有利于将字符串的内容放入不同的数据库字段