簡體   English   中英

JDBC模板異常表或視圖不存在但實際存在

[英]JDBC Template exception table or view does not exist but it actually exists

我正在嘗試使用 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 WHERE 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表?

請檢查是否有贈款,以及是否需要在表名前加上schema.table_name

這可能是由於您對該特定表沒有選擇權限

grant select on snow.ar_incident to your_user;

將 JDBC 驅動程序更新到更新版本后,所有問題都消失了。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM