如何使用IntelliJ中的JPA实体填充数据库

时间:2015-04-22 03:24:24

标签: java jpa intellij-idea entity persistence.xml

IntelliJ中是否有一种方法可以从我的实体类中创建数据库中的表?我的意思是没有ER图。 IDE允许我从DB创建实体,但不是相反。 我以前使用netbeans,它只是让你添加实体到persistense.xml和选择模式(删除和创建,创建等),但我在IntelliJ中找不到这些选项。 我已配置de DB连接并且它可以工作,它只是不允许我用我的实体填充它。

这是NetBeans的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="ClubPU2" transaction-type="RESOURCE_LOCAL">
    <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
    <class>baseclub.entidades.Actividad</class>
    <class>baseclub.entidades.Comercio</class>
    <class>baseclub.entidades.Contacto</class>
    <class>baseclub.entidades.Cuota</class>
    <class>baseclub.entidades.DatosInstitucionales</class>
    <class>baseclub.entidades.DatosPersonales</class>
    <class>baseclub.entidades.Descuento</class>
    <class>baseclub.entidades.Identificacion</class>
    <class>baseclub.entidades.Miembro</class>
    <class>baseclub.entidades.NotaEntrada</class>
    <class>baseclub.entidades.Participacion</class>
    <class>baseclub.entidades.Rol</class>
    <class>baseclub.entidades.Secretaria</class>
    <class>baseclub.entidades.Sesion</class>
    <class>baseclub.entidades.Tutor</class>
    <class>baseclub.entidades.Ubicacion</class>
    <class>baseclub.entidades.Usuario</class>
    <exclude-unlisted-classes>false</exclude-unlisted-classes>
    <properties>
      <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/club_universitario?zeroDateTimeBehavior=convertToNull"/>
      <property name="javax.persistence.jdbc.password" value="XXXXXX"/>
      <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
      <property name="javax.persistence.jdbc.user" value="club"/>
      <property name="javax.persistence.schema-generation.database.action" value="create"/>
    </properties>
  </persistence-unit>
</persistence>

这是IntelliJ的persistence.xml:

<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence" version="2.0">

    <persistence-unit name="persistenceUnit">

    </persistence-unit>
</persistence>

1 个答案:

答案 0 :(得分:0)

您是否有任何特殊原因希望IntelliJ创建数据库?

如果您选择Hibernate作为ORM,您只需在persistence.xml中添加以下代码:

 <property name="hibernate.hbm2ddl.auto" value="update" />

启动应用程序服务器,部署应用程序,然后创建数据库。