我正在尝试运行一个简单的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。
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
答案 0 :(得分:4)
也许您需要指定架构,或类似的东西:
@Entity
@Table(schema = "HR")
public class Idt { ... }
还要确保Hibernate(SYSTEM
)使用的帐户有权访问该表。
答案 1 :(得分: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>
我希望有一天能帮到某人。
答案 2 :(得分:0)
答案 3 :(得分:0)
也许您选择了错误的数据库:
JDBC:预言:瘦:@localhost:1521 / <强> XE 强>
创建表格“ HR ”。“IDT”
答案 4 :(得分:0)
我的问题:在我的情况下,我有两个数据库(DB-1和DB-2)和我需要insert/modify
所需的表在DB-2中我连接到DB-1。
我的解决方案:使用DB-2.table name
在DB-1中创建公共同义词。
脚本(在DB-1中执行):
CREATE OR REPLACE PUBLIC SYNONYM "TABLE" FOR "SYNONYMOUS "."TABLE"@"PARAMETRAGE_LINK";
答案 5 :(得分:0)
java.sql.SQLException:ORA-00942:表或视图不存在。
此异常表示您的表未创建,并且您正在对其执行查询。因此,要解决此异常,您必须先创建表...
将此行添加到配置文件中。这里Hibernate会自动创建你的表。
<property name="hbm2ddl.auto">create</property>
但是如果你想更新你的表格,请改用
<property name="hbm2ddl.auto">update</property>
答案 6 :(得分:0)
在休眠配置文件中使用<property name="javax.persistence.schema-generation.database.action">
创建</property>
。瞧.. !!
答案 7 :(得分:0)
在我的情况下,我与一个没有GRANT的用户在表和模式上与Hibernate进行了连接。
答案 8 :(得分:0)
问题可能是由于外键或同义词映射的不同表(可能不存在或授予权限不适用于该表)。
对我来说,问题在于该表中的一列与另一个模式表有映射关系,但它丢失了。例如,公共同义词。