JDBC模板异常表或视图不存在,但实际上存在

时间:2018-08-29 09:47:05

标签: java spring oracle spring-boot jdbctemplate

我正在尝试使用Spring JDBCTemplate从Oracle DB获取一些数据:

String query = "SELECT * FROM snow.ar_incident WHERE ROWNUM < 10";

    Map<String, List<Attachment>> map = jdbcTemplate.query(query, new ResultSetExtractor<Map<String, List<Attachment>>>() {

        @Override
        public Map<String, List<Attachment>> extractData(ResultSet rs) throws SQLException, DataAccessException {
            Map<String, List<Attachment>> map = new HashMap<>();
            //Mapping results to map
            return map;
        }
    });

但是我总是只为ar_incidient表获得一个例外:

  

原因:org.springframework.jdbc.BadSqlGrammarException:   StatementCallback;错误的SQL语法[SELECT * from   snow.ar_incident WROWE ROWNUM <10];嵌套异常为   java.sql.SQLSyntaxErrorException:ORA-00942:表或视图不   存在

此代码对其他表完全适用,但不适用于此表。我还尝试使用核心Java sql连接从该表中获取数据:

Class.forName("oracle.jdbc.driver.OracleDriver");  
Connection con = DriverManager.getConnection(connString, user, pass);    
Statement stmt=con.createStatement();   
ResultSet rs = stmt.executeQuery("SELECT * from snow.ar_incident WHERE ROWNUM < 10");  

它工作正常,与我在SQL Developer中运行查询时相同。我已经多次检查了这两种解决方案的连接详细信息,并且它们是相同的。为什么我不能使用JDBCTemplate访问ar_incident表?

3 个答案:

答案 0 :(得分:0)

这可能是由于您在该特定表上没有选择特权而引起的

grant select on snow.ar_incident to your_user;

答案 1 :(得分:0)

将JDBC驱动程序更新为较新版本后,所有问题均消失了。

答案 2 :(得分:0)

请检查是否有赠予,并且是否需要在表名前添加 schema.table_name