java - ORA-00942 Hibernate 出现 SQLException(无法找到表)

标签 java oracle hibernate mapping ora-00942

我正在尝试运行一个简单的 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

最佳答案

也许您需要指定模式或类似的东西:

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

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

关于java - ORA-00942 Hibernate 出现 SQLException(无法找到表),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5714443/

相关文章:

java - ClassName.class.getResourceAsStream 返回 Null

sql - Oracle 日期差异 SQL 查询

java - 我是否需要为列设置自动增量才能生成 identit 工作

java - 在客户端-服务器模型中使用 Hibernate

java - Collectors.tomap 和 HeaderEelement 的 getValue 和 getNmae 的问题

java - 通过 AGI 将 Asterisk 绑定(bind)到我的 Java 程序

sql - LENGTH 命令的奇怪行为 - ORACLE

java - 将 jdbc 驱动程序添加到类路径

Java动画,带有关键监听器

Oracle 使用通配符进行模糊文本搜索