为什么休眠不会自动创建表,即使有 hibernate.hbm2ddl.auto" 值 = PP_5 ?



如果hibernate不存在,我试图强制它创建一个学生表,但如果没有成功,hibernate库应该能够做到这一点,但我收到一个错误,说数据库中没有这样的表,不确定问题出在哪里:

详细信息:

学生班

import javax.persistence.Entity;
import javax.persistence.Id;

@Entity
public class Student {
@Id
int id;
int phoneNumber;
public Student() {
}
public Student(int id, int phoneNumber) {
this.id = id;
this.phoneNumber = phoneNumber;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public int getPhoneNumber() {
return phoneNumber;
}
public void setPhoneNumber(int phoneNumber) {
this.phoneNumber = phoneNumber;
}
}

主要类别

public class Main {
public static void main(String[] args) {
EntityManagerFactory entityManagerFactory = Persistence.createEntityManagerFactory("ss");
EntityManager entityManager = entityManagerFactory.createEntityManager();

Student student = new Student(5,55);

entityManager.getTransaction().begin();
entityManager.persist(student);
entityManager.getTransaction().commit();
}
}

Persistence.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.1"
xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd">
<persistence-unit name="ss" transaction-type="RESOURCE_LOCAL">
<class>com.youssef.Student</class>
<properties>
<property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" />
<property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/sotamag" />
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect" />
<property name="javax.persistence.jdbc.user" value="root" />
<property name="javax.persistence.jdbc.password" value="" />
<property name="hibernate.hbm2ddl.auto" value="create"/>

</properties>
</persistence-unit>
</persistence>

注意:

-我添加了以下属性<property name="hibernate.hbm2ddl.auto" value="create"/>来强制hibernate创建表,但仍然收到错误消息,说数据库中没有这样的表。

-我使用MySQL作为数据库`

如果您使用MySQL5或更高版本,您可以尝试将您的方言更改为:

<property name="hibernate.dialect">org.hibernate.dialect.MySQL55Dialect</property>

相关内容

最新更新