Hibernate启动时需要做很多事情,如果实体类不是很多还好,如果很多,我们项目中目前大概有500左右,那么启动速度会很慢,如何加快hibernate的启动速度,网上有很多文章已经阐述了部分,不再重复,补充一些:
一.避免使用@NamedQuery,hibernate在启动时会执行namedQuery的绑定/校验等工作,实在避免不了,那么考虑将校验关闭(hibernate.query.startup_check=false)
二.将hibernate.hbm2ddl.auto设置为none,如果实在要进行update的工作,可以按模块进行update,如在packages.txt中指定POJO的包名,然后根据包名update涉及的表,下面的代码供参考:
protected void updateDatabaseSchema() {
try {
//从packages.txt中读取包名列表
List<String> packages = null;
Resource resource = resourceLoader.getResource("classpath:packages.txt");
if (resource.exists()) {
packages = new ArrayList<String>();
List<String> lines = FileUtils.readLines(resource.getFile(), "UTF-8");
if (lines != null) {
for (String line : lines) {
if (StringUtils.isNotEmpty(line.trim()) && !packages.contains(line.trim()))
packages.add(line.trim());
}
}
}
//设置configuration的tables字段
Field tablesField = ReflectionUtils.findField(Configuration.class, "tables");
ReflectionUtils.makeAccessible(tablesField);
Configuration configuration = localSessionFactoryBean.getConfiguration();
Map tables = (Map) ReflectionUtils.getField(tablesField, configuration);
try {
Map tempTables = new HashMap();
Iterator it = configuration.getClassMappings();
while (it.hasNext()) {
PersistentClass model = (PersistentClass) it.next();
if (model.getMappedClass() != null && model.getTable() != null) {
String packageName = ClassUtils.getPackageName(model.getMappedClass());
if (packages == null || contains(packages, packageName)) {
tempTables.put(model.getTable().getName(), model.getTable());
}
}
}
ReflectionUtils.setField(tablesField, localSessionFactoryBean.getConfiguration(), tempTables);
new SchemaUpdate(configuration, ((SessionFactoryImplementor) localSessionFactoryBean.getObject()).getSettings()).execute(false, true);
} finally {
ReflectionUtils.setField(tablesField, localSessionFactoryBean.getConfiguration(), tables);
}
} catch (Exception ex) {
throw new NestedRuntimeException("Exception", ex);
}
}
protected boolean contains(List<String> packages, String packageName) {
for (String pkgName : packages) {
if (StringUtils.contains(packageName, pkgName))
return true;
}
return false;
}
分享到:
相关推荐
### Flex 4.5 + BlazseDS + Spring3 + Hibernate3.3 开发环境搭建详解 #### 核心知识点: 1. **Flex 4.5**:Adobe Flex 是一个强大的开源框架,用于构建和部署跨平台的桌面和移动应用程序。Flex 4.5 提供了增强的...
本篇文章将深入探讨如何对Hibernate进行优化,以提高应用程序的效率。 **一、配置优化** 1. **连接池配置**:使用高效的连接池如C3P0、HikariCP,它们能有效管理数据库连接,避免频繁创建和关闭连接,从而提升性能...
本文将基于Hibernate 3.2.5的源码,结合Eclipse开发环境,探讨其核心机制,帮助开发者深入理解并掌握这一强大的工具。 一、Hibernate概览 Hibernate允许开发者使用面向对象的编程模型来操作数据库,消除了SQL与Java...
综上所述,这个压缩包提供了一个完整的Hibernate学习和开发环境,从基础理论到实践操作,涵盖了代码生成、配置、缓存以及核心功能的使用。对于Java开发者来说,掌握Hibernate插件的使用将极大地提升开发效率和项目...
"Spring Hibernate Ext"项目是...总的来说,"Spring Hibernate Ext"项目提供了一个集成Spring和Hibernate的高级平台,结合了两者的优势,并添加了一些实用的扩展功能,为开发者提供了高效、便捷的企业级应用开发环境。
Eclipse 3.7(Indigo)中的Hibernate Tools是一个强大的集成开发环境插件,它为开发者提供了在Eclipse中高效地处理Hibernate ORM框架的能力。这个插件极大地简化了与Hibernate相关的开发任务,如实体类的生成、...
根据题目中的内容,我们将具体介绍如何在 MyEclipse 环境下配置 Hibernate 的数据库连接。 ##### 1. 打开 MyEclipse - **启动 MyEclipse**:首先启动 MyEclipse 开发工具。 - **切换视图**:在 MyEclipse 中切换到...
- 开发环境准备:首先,你需要创建一个开发目录,将Hibernate 3.1.2发布的所有必要库文件放入`lib`目录,包括antlr.jar、cglib.jar、asm.jar等,以及主要的hibernate3.jar。根据README.txt确定具体所需的库文件。 ...
它是Hibernate启动时加载的第一个配置文件。 2. **实体类的XML映射文件**: 对应数据库表的Java类,每个类通常有一个对应的`.hbm.xml`文件,用于描述类与表之间的映射关系。 样例代码通常包括以下部分: 1. **...
Hibernate支持JDBC,可以与任何兼容的Java EE或Java SE环境配合使用。 二、安装与配置 安装Hibernate通常包括下载其jar文件并将其添加到项目的类路径中。配置文件`hibernate.cfg.xml`用于定义数据库连接参数,包括...
Hibernate是一款强大的对象关系映射(ORM)框架,它在Java编程环境中广泛用于简化数据库操作。在Java应用程序中,Hibernate提供了一种方式,使得开发者可以使用面向对象的编程模型来处理数据库,而无需直接编写SQL...
【Hibernate雨夜的寂寞原创教程】是一份专为初学者设计的教程,旨在帮助学习者掌握Hibernate这一强大的Java对象关系映射(ORM)框架。...通过实践,你将能更好地理解和运用Hibernate,提升Java开发中的数据库操作效率。
3. SessionFactory:它是Hibernate的核心工厂类,负责创建Session实例,通常在应用启动时初始化。 三、主要接口与类 1. Session:作为数据库会话,提供了增删查改(CRUD)操作,同时支持事务管理和缓存管理。 2. ...
正确理解和使用这个库,能够大大提高开发效率,同时降低维护成本。然而,为了使用更高级的功能,如 Criteria API、CGLIB代理、JMX监控等,可能还需要引入其他的Hibernate JAR包。因此,根据项目需求,适时地添加额外...
**正文** Hibernate是一种开源的对象关系映射(ORM)框架,它极大地简化了Java开发者与数据库交互的工作。在Java世界中,Hibernate...理解和熟练掌握Hibernate方法的实现,对于提高开发效率和维护质量具有重要意义。
通过内部代码优化,Hibernate 4.3.9 减少了内存占用,提高了启动速度和运行效率。此外,对于大批量数据操作,也进行了性能调优。 6. **元数据API**: 元数据API得到了增强,使得获取实体和关联信息更加方便,这...