mybatis项目报错:java.sql.SQLException: ORA-00911: 无效字符 解决方法

时间:2021-08-03 22:53:34

如果你用java写程序访问数据库,出现这个问题:
java.sql.SQLException: ORA-00911: 无效字符

at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:112)
at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:331)
at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:288)
at oracle.jdbc.driver.T4C8Oall.receive(T4C8Oall.java:743)
at oracle.jdbc.driver.T4CPreparedStatement.doOall8(T4CPreparedStatement.java:216)
at oracle.jdbc.driver.T4CPreparedStatement.executeForDescribe(T4CPreparedStatement.java:799)
at oracle.jdbc.driver.OracleStatement.executeMaybeDescribe(OracleStatement.java:1037)
at oracle.jdbc.driver.T4CPreparedStatement.executeMaybeDescribe(T4CPreparedStatement.java:839)
at oracle.jdbc.driver.OracleStatement.doExecuteWithTimeout(OracleStatement.java:1132)
at oracle.jdbc.driver.OracleStatement.doScrollExecuteCommon(OracleStatement.java:4051)

 

百度了下:网上达人们给出如下解决方法: 

 原因是:你的sql多了一个";" 去掉就可以了 

但是,这只是针对单条语句的解决办法,如果是批处理,就算你不少‘:’也是不行的,我在PLSQL中试了一下,

如果写在一行是不行的,但是分行写是可以的,奇怪,黑线中~~,

又百度了一波,找到了解决办法,

在批处理外面套上 begin;....end;

完美解决,但是中间的语句也是不能少“;”的,不然还是会报错,切记!