当前位置: 首页 > 面试题库 >

在persistence.xml的jta-data-source中放入什么?

陆博易
2023-03-14
问题内容

我应该把什么样的价值为<jta-data-source>我的persistence.xml

在glassfish管理面板中,我创建了一个数据源名称"abcDS"。在我的jndi.properties(内部src/test/resources)我是这样定义的:

[...]
abcDS=new://Resource?type=DataSource
abcDS.JdbcDriver=org.hsqldb.jdbcDriver
abcDS.JdbcUrl=jdbc:hsqldb:mem:testdb
abcDS.JtaManaged=true
[...]

我应该放入persistence.xml什么?我发现了很多变种在网络,如:"jdbc/abcDS""java:/abcDS""abcDS"。哪一个是对的?对此有一些规定吗?我了解这与JNDI有关,但是…

我正在尝试在单元测试中创建EMF:

EntityManagerFactory emf = Persistence.createEntityManagerFactory("abc");

这是我要登录的日志:

[...]
SEVERE: Could not find datasource: abcDS javax.naming.NameNotFoundException: 
    Name "abcDS" not found.
at org.apache.openejb.core.ivm.naming.IvmContext.federate(IvmContext.java:193)
at org.apache.openejb.core.ivm.naming.IvmContext.lookup(IvmContext.java:150)
at org.apache.openejb.core.ivm.naming.ContextWrapper.lookup(ContextWrapper.java:115)
at javax.naming.InitialContext.lookup(InitialContext.java:392)
[...]

问题答案:

问题在于这Persistence.createEntityManagerFactory("abc")是“自己动手”
API,并且没有利用嵌入式EJB容器。您可以EntityManager非常轻松地在测试用例中管理一个容器。

与相关的jndi /
datasource问题一样,我建议您在examples.zip中查看示例。他们都是为了摆脱起步之苦而设计的。

这是该testcase-injection示例的片段,该示例显示了如何从容器中获取EntityManager和其他内容以用于测试。

首先,向测试中添加一个空的ejb-jar.xml或application-client.xml,以打开扫描测试代码的步骤:

  • src / test / resources / META-INF / application-client.xml

然后,使用注释您的测试用例,@org.apache.openejb.api.LocalClient并将标准JavaEE注释用于实际注入。

@LocalClient
public class MoviesTest extends TestCase {

    @EJB
    private Movies movies;

    @Resource
    private UserTransaction userTransaction;

    @PersistenceContext
    private EntityManager entityManager;

    public void setUp() throws Exception {
        Properties p = new Properties();
        p.put(Context.INITIAL_CONTEXT_FACTORY, "org.apache.openejb.client.LocalInitialContextFactory");
        p.put("movieDatabase", "new://Resource?type=DataSource");
        p.put("movieDatabase.JdbcDriver", "org.hsqldb.jdbcDriver");
        p.put("movieDatabase.JdbcUrl", "jdbc:hsqldb:mem:moviedb");

        InitialContext initialContext = new InitialContext(p);

        // Here's the fun part
        initialContext.bind("inject", this);
    }

作为movieDatabase我们设置的唯一数据源,OpenEJB会自动将该数据源分配给您的持久性单元,而无需修改您的persistence.xml。您甚至可以将<jta- data-source>或留为<non-jta-data-source>空白,OpenEJB仍然会知道该怎么做。

但是为了完整起见,以下是此特定应用程序如何定义 persistence.xml

<persistence xmlns="http://java.sun.com/xml/ns/persistence" version="1.0">

  <persistence-unit name="movie-unit">
    <jta-data-source>movieDatabase</jta-data-source>
    <non-jta-data-source>movieDatabaseUnmanaged</non-jta-data-source>
    <class>org.superbiz.testinjection.Movie</class>

    <properties>
      <property name="openjpa.jdbc.SynchronizeMappings" value="buildSchema(ForeignKeys=true)"/>
    </properties>
  </persistence-unit>
</persistence>

然后是有趣的部分,在测试中一起使用

public void test() throws Exception {

    userTransaction.begin();

    try {
        entityManager.persist(new Movie("Quentin Tarantino", "Reservoir Dogs", 1992));
        entityManager.persist(new Movie("Joel Coen", "Fargo", 1996));
        entityManager.persist(new Movie("Joel Coen", "The Big Lebowski", 1998));

        List<Movie> list = movies.getMovies();
        assertEquals("List.size()", 3, list.size());

        for (Movie movie : list) {
            movies.deleteMovie(movie);
        }

        assertEquals("Movies.getMovies()", 0, movies.getMovies().size());

    } finally {
        userTransaction.commit();
    }
}


 类似资料:
  • 一、内置 Data Source Flink Data Source 用于定义 Flink 程序的数据来源,Flink 官方提供了多种数据获取方法,用于帮助开发者简单快速地构建输入流,具体如下: 1.1 基于文件构建 1. readTextFile(path):按照 TextInputFormat 格式读取文本文件,并将其内容以字符串的形式返回。示例如下: env.readTextFile(fil

  • 让我们在数据库TEST创建一个数据库表Student 。 我假设您正在使用MySQL数据库,如果您使用任何其他数据库,那么您可以相应地更改您的DDL和SQL查询。 CREATE TABLE Student( ID INT NOT NULL AUTO_INCREMENT, NAME VARCHAR(20) NOT NULL, AGE INT NOT NULL, PRIM

  • 让我们在数据库TEST创建一个数据库表Student 。 我假设您正在使用MySQL数据库,如果您使用任何其他数据库,那么您可以相应地更改您的DDL和SQL查询。 CREATE TABLE Student( ID INT NOT NULL AUTO_INCREMENT, NAME VARCHAR(20) NOT NULL, AGE INT NOT NULL, PRIM

  • 问题内容: 在工作中,我们有一个实体库,供多个客户端使用该实体库(几个servlet,一个桌面应用程序等)。实体库由JPA注释的类和最著名的persistence.xml组成。 所有项目都使用maven进行配置。 应该将persistence.xml文件放在哪里?它需要位于该实体库的jar文件中,而且我不确定如何使用maven进行配置。 (我们只是将一个项目分成几个较小的项目) ’‘’UPDATE

  • a)如果我把persistence.xhtml放在src/main/java/META-INF/Gradle不会将其包含在生成的jar文件中,因为它不是java文件。 b)如果我把它放在src/main/Resources/META-INF/Gradle会将它包含在生成的jar文件中但是Eclipse会抱怨"Nopersistence.xmlfile find in project"即使我在源代码

  • 我正在寻找如何在项目视图中显示打开的文件,并找到了这两个功能,我想知道上面提到的功能是什么?