2013-10-28 31 views
0

我的應用程序在嵌入模式下使用JPA和JavaDB。在persistence.xml文件我用這個屬性:如何使用嵌入的JPA和JavaDB從Java代碼創建數據庫表?

<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

您可以使用JPA休眠,然後使用配置選項hibernate.hbm2ddl.auto=create

+0

如何?這些表是從實體創建的嗎? – ceklock

+0

不是,來自映射但實體用於創建它。檢查文檔* persistence.xml *如何將實體映射到類。 – 2013-10-28 19:00:27

+0

我想我已經有了映射。對不起,但我不會使用Hibernate。我正在使用EclipseLink,我認爲它是類似的......我只是不知道是否最好使用純sql來創建表格,或者從實體/映射創建它們......我不知道實體是否會像SQL一樣生成表格。 – ceklock

相關問題