【问题标题】:ORA-00942 SQLException with Hibernate (Unable to find a table)ORA-00942 SQLException with Hibernate(找不到表)
【发布时间】:2011-08-08 12:54:27
【问题描述】:

我正在尝试运行一个简单的 Hibernate 应用程序,但出现此错误:

org.hibernate.exception.SQLGrammarException: could not execute query
java.sql.SQLException: ORA-00942: table or view does not exist

我的实体:

package beans;

import javax.persistence.*;

@Entity
public class Idt {
    @Id
    private int id;
    @Column(name="name")
    private String name;

    public Idt(){
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}

我的表在 Hr 用户中被称为 IDT。

CREATE TABLE "HR"."IDT"
  (
    "ID"   NUMBER NOT NULL ENABLE,
    "NAME" VARCHAR2(20 BYTE),
    CONSTRAINT "IDT_PK" PRIMARY KEY ("ID") USING INDEX PCTFREE 10 INITRANS 2 MAXTRANS 255 STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT) TABLESPACE "USERS" ENABLE
  )
  PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING STORAGE
  (
    INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT
  )
  TABLESPACE "USERS" ;

Hibernate.cfg.xml:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
          "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
          "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

            <hibernate-configuration>

                <session-factory>

                    <!-- Database connection settings -->
                    <property name="connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
                    <property name="connection.url">jdbc:oracle:thin:@localhost:1521/xe</property>
                    <property name="connection.username">SYSTEM</property>
                    <property name="connection.password">19141914</property>

                    <!-- SQL dialect -->
                    <property name="dialect">org.hibernate.dialect.OracleDialect</property>

                    <!-- Echo all executed SQL to stdout -->
                    <property name="show_sql">true</property>

                    <property name="current_session_context_class">thread</property>

                    <mapping class="beans.Idt"/>



                </session-factory>

            </hibernate-configuration>     

我猜是因为SQLException,实体的映射有问题:

java.sql.SQLException: ORA-00942: table or view does not exist

【问题讨论】:

    标签: java oracle hibernate mapping ora-00942


    【解决方案1】:

    也许您需要指定架构或类似的东西:

    @Entity 
    @Table(schema = "HR")
    public class Idt { ... }
    

    还要确保 Hibernate (SYSTEM) 使用的帐户有权访问该表。

    【讨论】:

    • +1:也不要使用 SYSTEM,它是 Oracle 保留的模式。使用您自己的架构 :)
    • 我遇到了同样的问题,@Table(schema) 也是答案
    【解决方案2】:

    我遇到了同样的问题,经过很长时间试图找出我得到了

    java.sql.SQLException: ORA-00942: table or view does not exist
    

    我发现它是因为该应用程序无法访问存储在我的数据库中名为 "system" 的架构下的表。通过在我的 Hibernate.cfg.xml file 中添加以下行来解决问题:这是添加的行以提供对我创建的表的绝对路径/访问权限。

    <property name="hibernate.default_schema">system</property> 
    

    这是完整的hibernate.cfg.xml 配置:

    <?xml version="1.0" encoding="utf-8"?>
    <!DOCTYPE hibernate-configuration PUBLIC
    "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
    <hibernate-configuration>
        <session-factory>
            <property name="hibernate.connection.driver_class">oracle.jdbc.OracleDriver</property>
            <property name="hibernate.connection.url">jdbc:oracle:thin:@localhost:1521:oracledb</property>
            <property name="hibernate.connection.username">usrname</property>
            <property name="hibernate.connection.password">password</property>
            <property name="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</property>
            <property name="hibernate.default_schema">system</property>
            <property name="show_sql">true</property>
            <mapping resource="com/mkyong/user/DBUser.hbm.xml"></mapping>
        </session-factory>
    </hibernate-configuration>
    

    我希望有一天这会对某人有所帮助。

    【讨论】:

      【解决方案3】:

      在我的情况下,我与 Hibernate 连接,用户在我试图查询的表和架构上没有 GRANT。

      【讨论】:

      • 值得注意的一点。我也有同样的问题,这个线索确实有帮助。谢谢。 :)
      【解决方案4】:

      您可能缺少'@Table' 注释。

      你可以这样添加:

      @Entity
      @Table(name="idt")
      public class Idt {
          ...
      }
      

      【讨论】:

        【解决方案5】:

        也许你选择了错误的数据库:

        jdbc:oracle:thin:@localhost:1521/xe

        创建表“HR”.“IDT”

        【讨论】:

          【解决方案6】:

          我的问题:就我而言,我有两个数据库(DB-1 和 DB-2),当我连接到 DB-1 时,我需要 insert/modify 的表在 DB-2 中。
          我的解决方案:在 DB-1 中使用DB-2.table name 创建一个公共同义词。

          脚本(在 DB-1 中执行):
          CREATE OR REPLACE PUBLIC SYNONYM "TABLE" FOR "SYNONYMOUS "."TABLE"@"PARAMETRAGE_LINK";

          【讨论】:

            【解决方案7】:

            java.sql.SQLException: ORA-00942: 表或视图不存在。

            此异常意味着您的表尚未创建,您正在对其执行查询。因此,要解决此异常,您必须先创建表...

            将此行添加到您的配置文件中。这里 Hibernate 会自动创建你的表。

            <property name="hbm2ddl.auto">create</property>
            

            但如果你想进一步更新你的表格,请改用这个,

            <property name="hbm2ddl.auto">update</property>
            

            【讨论】:

              【解决方案8】:

              在你的休眠配置文件中使用&lt;property name="javax.persistence.schema-generation.database.action"&gt;create&lt;/property&gt;。瞧……!!

              【讨论】:

                【解决方案9】:

                问题可能是由于外键或同义词映射的不同表(可能不存在或授予权限不适用于该表)。

                对我来说,问题在于该表中的一列与另一个模式表有映射,并且它缺少.ex,公共同义词。

                【讨论】:

                  猜你喜欢
                  • 1970-01-01
                  • 2020-03-01
                  • 2015-11-09
                  • 2011-12-10
                  • 2019-01-22
                  • 2019-09-21
                  • 2015-01-30
                  • 2016-08-23
                  相关资源
                  最近更新 更多