0

0

Jakarta EE JPA 容器管理实体管理器与内存数据库配置指南

心靈之曲

心靈之曲

发布时间:2025-11-27 16:08:22

|

801人浏览过

|

来源于php中文网

原创

Jakarta EE JPA 容器管理实体管理器与内存数据库配置指南

本教程详细阐述了在 jakarta ee 环境中,如何利用 `@datasourcedefinition` 注解配置容器管理的 jpa 实体管理器以使用内存数据库(如 hsqldb)。文章涵盖了 `persistence.xml` 的 jta 数据源设置、`@datasourcedefinition` 的使用方法及注意事项,旨在帮助开发者实现便捷的测试环境部署和事务管理。

容器管理 JPA 实体管理器概述

在 Jakarta EE 应用中,容器管理的 JPA 实体管理器(Container-Managed EntityManager)是推荐的实践方式。它通过依赖注入(@PersistenceContext)提供 EntityManager 实例,并与容器的 JTA(Java Transaction API)事务管理器集成,允许开发者使用声明式事务(@Transactional)来简化事务管理,无需手动处理事务的开始、提交和回滚。

要实现容器管理的实体管理器,persistence.xml 文件中的持久化单元必须声明 transaction-type="JTA",并且需要通过 元素引用一个 JTA 数据源。这个数据源通常通过 JNDI (Java Naming and Directory Interface) 名称在应用服务器中进行查找。

配置内存数据库的数据源

当使用内存数据库(如 HSQLDB)进行开发或测试时,我们希望能够方便地定义和引用数据源,而无需依赖复杂的服务器特定配置。Jakarta EE 提供了 @DataSourceDefinition 注解,允许在应用程序代码中以编程方式定义数据源,并使其通过 JNDI 可用。

使用 @DataSourceDefinition 定义数据源

@DataSourceDefinition 注解可以放置在一个普通的 Java 类上,通常是一个空的类,其主要目的是承载此注解。以下是如何为 HSQLDB 内存数据库定义数据源的示例:

import jakarta.annotation.sql.DataSourceDefinition;

/**
 * HSQLDB内存数据库的数据源定义。
 * 此类仅用于承载@DataSourceDefinition注解,本身无需任何方法或字段。
 */
@DataSourceDefinition(
    class = "org.hsqldb.jdbcDriver", // JDBC驱动类名
    name = "java:app/jdbc/testdb", // JNDI名称,供persistence.xml引用
    url = "jdbc:hsqldb:mem:testdb;DB_CLOSE_DELAY=-1", // HSQLDB内存数据库URL
    user = "sa", // 数据库用户名
    password = "" // 数据库密码
)
public class HsqldbDataSourceConfig {
    // 无需任何代码
}

注解属性说明:

  • class: 指定 JDBC 驱动的完全限定类名。对于 HSQLDB,通常是 org.hsqldb.jdbcDriver。
  • name: 这是数据源将在 JNDI 注册的名称。persistence.xml 中的 将使用此名称进行查找。建议使用 java:app/jdbc/YourDataSourceName 或 java:global/jdbc/YourDataSourceName 这样的 JNDI 命名约定。java:app 表示数据源在当前应用程序范围内可见。
  • url: 数据库的连接 URL。对于 HSQLDB 内存数据库,jdbc:hsqldb:mem:testdb 定义了一个名为 testdb 的内存数据库。DB_CLOSE_DELAY=-1 是 HSQLDB 特有的参数,表示在最后一个连接关闭后,数据库实例不会立即关闭,这对于测试非常有用,可以保持数据库状态。
  • user: 连接数据库的用户名。
  • password: 连接数据库的密码。

当应用程序部署到支持 Jakarta EE 的应用服务器时,容器会扫描并处理 @DataSourceDefinition 注解,将指定的数据源注册到 JNDI 目录中。

更新 persistence.xml 配置

一旦数据源通过 @DataSourceDefinition 定义并注册到 JNDI,persistence.xml 文件就需要引用这个 JNDI 名称,并且必须移除所有直接的 JDBC 连接属性,因为这些属性现在由 JNDI 数据源本身提供。

Runway Green Screen
Runway Green Screen

Runway 平台的AI视频工具,绿幕抠除、视频生成、动态捕捉等

下载

修改后的 persistence.xml 示例如下:




    
        
        java:app/jdbc/testdb
        demo.Jakarta.user.UserEntity 
        
            
            
            
        
    

关键点:

  • 元素的值必须与 @DataSourceDefinition 中 name 属性的值完全匹配。
  • jakarta.persistence.jdbc.driver、jakarta.persistence.jdbc.url、jakarta.persistence.jdbc.user 和 jakarta.persistence.jdbc.password 等属性不再需要,并且应该从 persistence.xml 中移除。这些信息现在由 JNDI 数据源提供。

使用容器管理的实体管理器和事务

配置完成后,您就可以在您的业务逻辑(如 Repository 或 Service 层)中注入容器管理的 EntityManager,并利用 @Transactional 注解进行事务管理。

import jakarta.persistence.EntityManager;
import jakarta.persistence.PersistenceContext;
import jakarta.transaction.Transactional;
import demo.Jakarta.user.UserEntity; // 假设您的实体类

/**
 * 用户数据访问层示例
 */
public class UserRepository {

    // 注入容器管理的EntityManager
    @PersistenceContext(unitName = "test")
    private EntityManager em;

    /**
     * 保存用户实体,由容器管理事务。
     * @param user 待保存的用户实体
     * @return 保存后的用户实体
     */
    @Transactional
    public UserEntity save(UserEntity user) {
        em.persist(user); // 持久化操作
        return user;
    }

    /**
     * 根据ID查找用户实体。
     * @param id 用户ID
     * @return 对应的用户实体,如果不存在则为null
     */
    public UserEntity findById(Long id) {
        return em.find(UserEntity.class, id);
    }
}

在上述示例中,@PersistenceContext(unitName = "test") 会注入一个与名为 "test" 的持久化单元关联的 EntityManager 实例。@Transactional 注解确保 save 方法在一个 JTA 事务中执行,容器会自动管理事务的生命周期。

注意事项与最佳实践

  1. 可移植性考量: 将数据源配置硬编码到应用程序的 @DataSourceDefinition 中,虽然方便,但会降低应用程序在不同环境(如开发、测试、生产)之间部署时的灵活性。在生产环境中,通常推荐通过应用服务器的管理控制台或特定配置文件来定义数据源,实现配置与代码的分离。这样,无需重新编译和打包应用程序即可更改数据源配置。
  2. JNDI 命名约定: 选择合适的 JNDI 名称。java:app/jdbc/ 作用域表示数据源在当前应用程序内可见,而 java:global/jdbc/ 则表示在整个应用服务器实例中可见。根据您的需求选择合适的命名空间。
  3. 事务管理器: 确保您的 Jakarta EE 应用服务器已正确配置 JTA 事务管理器,以便 @Transactional 注解能够正常工作。
  4. 开发测试优势: @DataSourceDefinition 策略特别适用于开发和测试阶段,尤其是在使用嵌入式或内存数据库时。它允许开发者快速启动和运行应用程序,无需复杂的服务器配置步骤,从而提高开发效率。

总结

通过 @DataSourceDefinition 注解,Jakarta EE 提供了一种便捷的方式来在应用程序内部定义和注册 JTA 数据源,尤其适用于使用内存数据库的开发和测试场景。结合 persistence.xml 中的 jta-data-source 配置,开发者可以轻松地利用容器管理的 JPA 实体管理器和声明式事务。尽管这种方法在开发阶段具有显著优势,但在生产环境中,仍需权衡其可移植性,并考虑采用服务器级别的配置方式。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

834

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

739

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

735

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

399

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16926

2023.08.03

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

26

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.6万人学习

C# 教程
C# 教程

共94课时 | 6.9万人学习

Java 教程
Java 教程

共578课时 | 46.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号