ORA-00942 SQLException с Hibernate (Невозможно найти таблицу) - PullRequest
1 голос
/ 19 апреля 2011

Я пытаюсь запустить простое приложение 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;
    }
}

Моя таблица называется IDT у пользователя Hr.

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

Ответы [ 8 ]

4 голосов
/ 19 апреля 2011

Возможно, вам нужно указать схему или что-то в этом роде:

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

Также убедитесь, что учетная запись, используемая Hibernate (SYSTEM), имеет права на доступ к этой таблице.

2 голосов
/ 11 февраля 2014

Я столкнулся с той же проблемой, и после долгого времени, пытаясь выяснить, я получаю

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>

Надеюсь, это когда-нибудь кому-нибудь поможет.

0 голосов
/ 26 апреля 2019

В моем случае я был связан с Hibernate с пользователем без GRANT для таблицы и схемы, к которой я пытался обратиться.

0 голосов
/ 31 августа 2018

используйте <property name="javax.persistence.schema-generation.database.action"> создайте </property> в своем файле конфигурации Hibernate. вуаля .. !!

0 голосов
/ 28 ноября 2017

java.sql.SQLException: ORA-00942: таблица или представление не существует.

Это исключение означает, что ваша таблица не создана, и вы выполняете запросы к ней. Таким образом, чтобы устранить это исключение, вы должны сначала создать таблицу ...

Добавьте эту строку в ваш файл конфигурации. Здесь Hibernate создаст вашу таблицу автоматически.

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

Но если вы хотите обновить свою таблицу, используйте вместо этого

<property name="hbm2ddl.auto">update</property>
0 голосов
/ 24 апреля 2013

Моя проблема: в моем случае у меня было две базы данных (DB-1 и DB-2), а таблица, где мне нужно было insert/modify, была в DB-2, когда я подключен к DB-1.
Мое решение: создать общедоступный синоним в DB-1 с DB-2.table name.

Скрипт (выполняется в БД-1):
CREATE OR REPLACE PUBLIC SYNONYM "TABLE" FOR "SYNONYMOUS "."TABLE"@"PARAMETRAGE_LINK";

0 голосов
/ 19 апреля 2011

Возможно, вы выбрали неправильную базу данных:

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

CREATE TABLE " HR ». "IDT"

0 голосов
/ 19 апреля 2011

Похоже, вам не хватает аннотации '@ Table' .

Вы можете добавить это так:

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