Hibernate配置文件加载失败怎么办?Hibernate配置加载详解

Hibernate 加载配置文件通常指加载核心配置文件(如 hibernate.cfg.xml)或映射文件(如 *.hbm.xml),以下是详细步骤和示例:

hibernate加载配置文件


核心配置文件加载

Hibernate 会自动在类路径(classpath)根目录下查找默认的 hibernate.cfg.xml 文件。

示例代码:

import org.hibernate.SessionFactory;
import org.hibernate.boot.MetadataSources;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
public class HibernateUtil {
    private static final SessionFactory sessionFactory = buildSessionFactory();
    private static SessionFactory buildSessionFactory() {
        // 创建服务注册器(自动加载 hibernate.cfg.xml)
        final StandardServiceRegistry registry = new StandardServiceRegistryBuilder()
                .configure() // 默认加载 src/main/resources/hibernate.cfg.xml
                .build();
        try {
            return new MetadataSources(registry)
                    .buildMetadata()
                    .buildSessionFactory();
        } catch (Exception e) {
            StandardServiceRegistryBuilder.destroy(registry);
            throw new ExceptionInInitializerError(e);
        }
    }
    public static SessionFactory getSessionFactory() {
        return sessionFactory;
    }
}

指定自定义配置文件路径

若配置文件不在默认位置或名称不同,需显式指定路径:

StandardServiceRegistry registry = new StandardServiceRegistryBuilder()
    .configure("configs/my-hibernate-config.xml") // 指定配置文件路径
    .build();

编程式配置(无XML文件)

直接通过代码配置参数:

hibernate加载配置文件

StandardServiceRegistry registry = new StandardServiceRegistryBuilder()
    .applySetting("hibernate.connection.driver_class", "com.mysql.cj.jdbc.Driver")
    .applySetting("hibernate.connection.url", "jdbc:mysql://localhost:3306/testdb")
    .applySetting("hibernate.connection.username", "root")
    .applySetting("hibernate.connection.password", "password")
    .applySetting("hibernate.dialect", "org.hibernate.dialect.MySQL8Dialect")
    .build();

映射文件加载

hibernate.cfg.xml 中声明映射文件:

<!-- hibernate.cfg.xml -->
<hibernate-configuration>
    <session-factory>
        <!-- 数据库配置 -->
        <property name="hibernate.connection.driver_class">com.mysql.cj.jdbc.Driver</property>
        <!-- 其他属性... -->
        <!-- 加载映射文件 -->
        <mapping resource="com/example/User.hbm.xml"/>
    </session-factory>
</hibernate-configuration>

或通过代码添加映射:

MetadataSources sources = new MetadataSources(registry)
    .addResource("com/example/User.hbm.xml"); // 手动添加映射文件

注解配置(无XML映射文件)

使用注解实体类时,在 hibernate.cfg.xml 中注册实体类:

hibernate加载配置文件

<session-factory>
    <!-- 数据库配置 -->
    <property name="hibernate.connection.url">jdbc:mysql:///test</property>
    <!-- ... -->
    <!-- 注册带注解的实体类 -->
    <mapping class="com.example.User"/>
</session-factory>

或通过代码注册:

MetadataSources sources = new MetadataSources(registry)
    .addAnnotatedClass(User.class); // 添加注解实体类

  1. 默认加载configure() 自动加载 classpath:hibernate.cfg.xml
  2. 自定义路径:使用 .configure("path/to/config.xml")
  3. 编程式配置:通过 .applySetting(key, value) 设置属性。
  4. 映射文件:在配置中通过 <mapping resource="..."/> 或代码添加。
  5. 注解实体:通过 <mapping class="..."/>addAnnotatedClass() 注册。

配置文件示例 (hibernate.cfg.xml):

<!DOCTYPE hibernate-configuration PUBLIC
    "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <!-- 数据库连接设置 -->
        <property name="hibernate.connection.driver_class">com.mysql.cj.jdbc.Driver</property>
        <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/testdb</property>
        <property name="hibernate.connection.username">root</property>
        <property name="hibernate.connection.password">password</property>
        <!-- 方言 -->
        <property name="hibernate.dialect">org.hibernate.dialect.MySQL8Dialect</property>
        <!-- 显示SQL -->
        <property name="hibernate.show_sql">true</property>
        <!-- 自动更新表结构 -->
        <property name="hibernate.hbm2ddl.auto">update</property>
        <!-- 注解实体类 -->
        <mapping class="com.example.User"/>
    </session-factory>
</hibernate-configuration>

通过以上方式,Hibernate 可正确加载配置并初始化 SessionFactory

图片来源于AI模型,如侵权请联系管理员。作者:酷小编,如若转载,请注明出处:https://www.kufanyun.com/ask/294108.html

(0)
上一篇 2026年2月12日 13:57
下一篇 2026年2月12日 14:00

相关推荐

  • 安全生产数据信息报送,如何确保高效精准与合规?

    安全生产的数据信息报送是现代企业安全管理的重要环节,它不仅是法律法规的明确要求,更是企业实现风险精准管控、提升本质安全水平的关键抓手,在数字化时代,如何高效、规范、精准地开展数据信息报送工作,成为企业安全管理必须破解的重要课题,安全生产数据信息报送的核心价值与意义安全生产数据信息报送的核心价值在于通过数据驱动安……

    2025年10月27日
    01110
  • windows启动配置数据

    Windows启动配置数据(Boot Configuration Data,简称BCD)是现代Windows操作系统(Vista及以后版本)中至关重要的核心组件,它取代了旧版系统中的boot.ini文件,BCD故障直接导致系统无法启动,表现为蓝屏、黑屏或提示“启动配置数据丢失”等错误, 解决BCD问题不仅需要理……

    2026年2月24日
    01095
  • 安全月黑板报怎么做?创意内容模板有哪些?

    安全月黑板报的意义与主题安全月黑板报是企业、学校及社区开展安全教育的重要载体,通过图文并茂的形式,将安全知识、事故案例、防护技能等内容直观呈现,增强读者的安全意识和自我保护能力,今年安全月以“人人讲安全、个个会应急”为主题,聚焦“遵守安全生产法,当好第一责任人”的核心要求,旨在推动安全文化深入人心,营造“人人关……

    2025年11月10日
    01910
    • 服务器间歇性无响应是什么原因?如何排查解决?

      根源分析、排查逻辑与解决方案服务器间歇性无响应是IT运维中常见的复杂问题,指服务器在特定场景下(如高并发时段、特定操作触发时)出现短暂无响应、延迟或服务中断,而非持续性的宕机,这类问题对业务连续性、用户体验和系统稳定性构成直接威胁,需结合多维度因素深入排查与解决,常见原因分析:从硬件到软件的多维溯源服务器间歇性……

      2026年1月10日
      020
  • 安全电子交易协议怎么开机?操作步骤是怎样的?

    在数字化经济快速发展的今天,金融交易的安全性与便捷性成为用户关注的核心,安全电子交易协议(SET)作为保障在线支付安全的重要技术框架,其运行机制涉及多个环节的协同,以下将从协议基础、运行流程、技术实现及实际应用等方面展开分析,并探讨类似协议在设备启动(开机)过程中的适配逻辑,安全电子交易协议的基础概念安全电子交……

    2025年10月23日
    01760

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注