如何使用嵌入的 JPA 和 JavaDB 从 Java 代码创建数据库表?

Posted

技术标签:

【中文标题】如何使用嵌入的 JPA 和 JavaDB 从 Java 代码创建数据库表?【英文标题】:How to create database tables from Java code using JPA and JavaDB embedded? 【发布时间】:2013-10-28 18:50:32 【问题描述】:

我的应用程序在嵌入式模式下使用 JPA 和 JavaDB。在persistence.xml 文件中,我使用了这个属性:

<property name="javax.persistence.jdbc.url" value="jdbc:derby:meuspiladb;create=true" />

所以如果它还不存在,将创建一个空数据库。

目前我有一个create_tables.sql 文件,我在其中放置了用于创建表的 SQL 代码,然后在创建数据库后手动运行它。我想让它成为自动的,但我不知道如何。

如果数据库是新的,我必须创建表。从 Java 代码创建它们的最佳方法是什么?


我的 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="MeusPila3_PU" transaction-type="RESOURCE_LOCAL">
    <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
    <class>br.meuspila.corretora.Corretora</class>
    <class>br.meuspila.ativo.Ativo</class>
    <class>br.meuspila.bolsa.Bolsa</class>
    <class>br.meuspila.movimento.Movimento</class>
    <class>br.meuspila.provento.Provento</class>
    <class>br.meuspila.operacao.Operacao</class>
    <properties>
      <property name="javax.persistence.jdbc.url" value="jdbc:derby:meuspiladb;create=true" />
      <property name="javax.persistence.jdbc.user" value="APP"/>
      <property name="javax.persistence.jdbc.driver" value="org.apache.derby.jdbc.EmbeddedDriver"/>
    </properties>
  </persistence-unit>
</persistence>

【问题讨论】:

【参考方案1】:

您可以将 Hibernate 与 JPA 一起使用,然后使用配置选项 hibernate.hbm2ddl.auto=create

【讨论】:

怎么样?表是从实体创建的吗? 不,来自映射,但实体用于创建它。查看文档以了解 persistence.xml 如何将实体映射到类。 我想我已经有了映射。抱歉,我不会使用 Hibernate。我正在使用 EclipseLink,我认为它是相似的...我只是不知道是使用纯 sql 创建表还是从实体/映射创建它们更好...我不知道实体是否会生成与 sql 完全相同的表。 您的提示适用于 Hibernate,但我发现 EclipseLink 有类似的东西,谢谢! 不完全是,但如果你从 sql 生成实体,那么它会是相似的。

以上是关于如何使用嵌入的 JPA 和 JavaDB 从 Java 代码创建数据库表?的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 netbeans 将 javadb 或 hsqldb 嵌入到带有休眠的 java 应用程序中?

JavaDB的一些问题

如何从另一台计算机连接到JavaDB?

内存中的 Java DB [关闭]

如何禁用嵌入式数据库 Spring-boot spring-data-jpa

Java应用如何使用JPA进行对象关系映射和持久化