gpt4 book ai didi

database - JPA 不从实体生成表

转载 作者:搜寻专家 更新时间:2023-10-30 20:10:37 25 4
gpt4 key购买 nike

这是一些实体:

@Entity
public class Forest {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private long id;


public Forest() {
}

public long getId() {
return id;
}

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

我想在表 Gson 林中插入一些元素:

public class Main {
private static EntityManagerFactory emf =
Persistence.createEntityManagerFactory("server");

public static void main(String[] args) {

EntityManager em = emf.createEntityManager();
EntityTransaction trx = em.getTransaction();
Forest forest = new Forest();


trx.begin();
em.persist(forest);
trx.commit();

}
}

抛出的异常:

Exception in thread "main" javax.persistence.PersistenceException: org.hibernate.exception.SQLGrammarException: Table 'server.forest' doesn't exist

Caused by: org.hibernate.exception.SQLGrammarException: Table 'server.forest' doesn't exist

我的带有设置的 persistence.xml 文件:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
<persistence-unit name="server">
<provider>org.hibernate.ejb.HibernatePersistence</provider>

<properties>
<property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
<property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/server"/>
<property name="javax.persistence.jdbc.user" value="root" />
<property name="javax.persistence.jdbc.password" value="root" />
<property name="hibernate.dialect" value="org.hibernate.dialect.HSQLDialect"/>
<property name="hibernate.hbm2ddl.auto" value="create-drop"/>
</properties>
</persistence-unit>
</persistence>

当我删除 @GeneratedValue(strategy = GenerationType.AUTO) 并为森林设置 id 时:forest.setID(1),没有异常,表已经生成。因此,自动生成 ID 不起作用,我不知道为什么。

最佳答案

根据配置,org.hibernate.dialect.HSQLDialect 与 MySQL 数据库一起使用。使用 MySQL 方言而不是其中一种 HSQL 可能会有所帮助。可能使用了 InnoDB - 如果是,则 MySQL5InnoDBDialect是路要走。

关于database - JPA 不从实体生成表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14902147/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com