eclipselink - 如何使用 jpa2 在内存中使用 derby?

标签 eclipselink jpa-2.0 derby in-memory-database

无论以下 persistence.xml 配置如何,数据库都将持久保存在磁盘上。

  <persistence-unit name="com.mysimpatico_inmemory_persistence_nbm_1.0-SNAPSHOTPU" transaction-type="RESOURCE_LOCAL">
<provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
<class>com.mysimpatico.memoplatform.persistence.entities.Expression</class>
<properties>
  <property name="javax.persistence.jdbc.url" value="jdbc:derby:memory:tempDb;create=true"/>
  <property name="javax.persistence.jdbc.password" value=""/>
  <property name="javax.persistence.jdbc.driver" value="org.apache.derby.jdbc.EmbeddedDriver"/>
  <property name="javax.persistence.jdbc.user" value=""/>
</properties>

http://wiki.apache.org/db-derby/InMemoryBackEndPrimer

最佳答案

我在内存中使用 Derby 进行测试,我的配置与您的非常接近。

这是我的 persistence.xml :

<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd" version="2.0">
  <persistence-unit name="TestPu" transaction-type="RESOURCE_LOCAL">
    <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
    <class>com.acme.Foo</class>
    <class>com.acme.Bar</class>
    <exclude-unlisted-classes>true</exclude-unlisted-classes>
    <properties>
      <!-- Common properties -->
      <property name="javax.persistence.jdbc.driver" value="org.apache.derby.jdbc.EmbeddedDriver"/>
      <property name="javax.persistence.jdbc.url" value="jdbc:derby:memory:test-jpa;create=true"/>
      <property name="javax.persistence.jdbc.user" value="APP"/>
      <property name="javax.persistence.jdbc.password" value="APP"/>

      <!-- EclipseLink specific properties -->
      <property name="eclipselink.target-database" value="Derby"/>
      <property name="eclipselink.ddl-generation" value="drop-and-create-tables"/>
      <property name="eclipselink.debug" value="ALL"/>
      <property name="eclipselink.weaving" value="static"/>
      <property name="eclipselink.logging.level" value="FINEST"/>
      <property name="eclipselink.logging.level.sql" value="FINEST"/>
      <property name="eclipselink.logging.level.cache" value="FINEST"/>
    </properties>
  </persistence-unit>
</persistence>

哪里org.apache.derby:derby:jar:10.6.2.1在类路径上。

现在有两个问题/建议:
  • 你怎么知道数据库是持久化在磁盘上的?
  • 如果确实如此,请确保您使用的是 persistence.xml你认为你是。
  • 关于eclipselink - 如何使用 jpa2 在内存中使用 derby?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4115498/

    相关文章:

    java - 如何使用 EclipseLink 配置 HikariCP

    java - JPA 和公历

    hibernate - 在 JPA 中是否可以将继承的属性重新定义为 transient ?

    hibernate - 在 EclipseLink 中映射列名和表名

    java - 如何支持我不拥有源代码的类的 jpa 数据库序列化?

    java - 注释m :n relationship with helper class (2 foreign keys + additional attributes) with JPA 2. 0

    jndi - Java EE 6嵌入式Glassfish嵌入式derby EJB单元测试

    Java 和数据库查询?

    java - 如何在 Jetty 的 Java Servlet 中使用 JavaDB 数据库?

    java - JPA "The multi-part identifier ... could not be bound"