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

标签 java jpa embedded-database javadb

我的应用程序在嵌入模式下使用 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>

最佳答案

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

关于java - 如何使用嵌入的 JPA 和 JavaDB 从 Java 代码创建数据库表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19642771/

相关文章:

java - 是否可以在 Web 应用程序中使用嵌入式数据库?

java - 使用 hibernate 进行缓慢的嵌入式数据库处理

java - .NET JPA 规范

jpa - hibernate jpa criteriabuilder 忽略大小写查询

hibernate - 将 Hibernate 切换到 iBatis

java - JDBC嵌入式Derby : No suitable driver found

java - 无法在此 Java 代码中找到 NullPointerException 的来源

java - HTTP/1.1 415 处理 JSON 时不支持的媒体类型

java - 根据 DTD 编写 XML

java - 如何正确使用Java客户端/服务器类