我的应用程序在嵌入模式下使用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>
答案 0 :(得分:1)
您可以将Hibernate与JPA一起使用,然后使用配置选项hibernate.hbm2ddl.auto=create
。