7、Oracle的;与ORA-00911: invalid character

本文探讨了在Oracle数据库中执行SQL语句时遇到的ORA-00911错误,并解释了该错误是由分号引起的。文章介绍了如何避免在Oracle环境中使用分号,以及在需要执行多条语句时的替代方案。

写SQL查询Oracle中的数据时容易遇到一个奇怪的问题:在一般的SQL developer查询分析器中写好的SQL语句运行一切正常,放到C#写的程序中提交 ORACLE执行就报错。错误代码如下:

ORA-00911: invalid character

这个问题是";"导致的。一般我们写SQL的时候都喜欢在每个语句结尾加上":",这也是一般写SQL的程序员的习惯。因为很多SQL的查询分析其时都会将这个分号当成一个语句的结束。但是,其实在正式执行的时候,因为Oracle的语法解析器特别严格,就会报出以上的错误出来,因此不能将这个分号扔到Oracle的解析器中的,解决方法也很简单,去掉分号就可以了。

在Mysql时我们通常可以执行多条语句“...;...;...;...;...;”这样,在ORACLE这里就行不通,需要在程序里对sql语句按照";"进行分割后分别执行。还有一种思路就是在语句后使用"/"迅速执行。

另外,";"在ORACLE的语句中并非是不能存在的,比如在函数、存储过程等都是可以存在的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值