`

NamingStrategy实现动态表名映射

阅读更多
NamingStrategy实现动态表名映射2008-06-02 10:25    用一个配置文件,一个类去映射多个表,(每个表的结构相同)。按照平时的做法,有多少个表就要
写多少个配置文件,岂不是很麻烦。怎样才能只写一个配置文件就能达到上述目的呢?

   经过研究,发现Hibernate中的NamingStrategy可以达到这个目的。它是用来定义表名和列名映射规
则的一个接口。我们要通过实现这个接口来实现自己的命名策略。这个接口中包含的十个方法,其中的
public String classToTableName(String className)是通过类名来映射表名的。实现我们的想法就要用
到这个方法。好了,下面来看怎么做:

   1、自定义一个类MyNamingStrategy来实现NamingStrategy。(这样你要实现10个方法,如果其他方法
不需要,我们可以通过继承它的一个适配器类DefaultNamingStrategy来只实现我们需要的方法)好了,我
们就继承DefaultNamingStrategy 吧。
  
      2、实现public String classToTableName(String className)方法来实现自己命名策略。

      例如业务需要是每隔一个月就要换一个表。比如1月用biz_1,那么2月就用biz_2....但是这些表的结构是相同的。我们要做的就是通过获得月份来动态的选择表。我们从这个方法中这样写:
    public class MyNamingStrategy extends DefaultNamingStrategy {
        public static final MyNamingStrategy INSTANCE = new MyNamingStrategy();
        public String classToTableName(String className) {
        return "biz_" + Calendar.getInstance().get(Calendar.DAY_OF_MONTH);
        }
    }

       好了,这样就可以根据月份来动态的选择表名了。

    3、使用命名策略。
       要使用这个命名策略可以这样:
       Configuration cfg = new Configuration()
               .setNamingStrategy(MyNamingStrategy.INSTANCE)
               .configure("hibernate.cfg.xml")
               .addFile("biz.hbm.xml");
----------------------------------
for exemple


package com.etong.common.hibernate;

import net.sf.hibernate.cfg.NamingStrategy;
import net.sf.hibernate.util.StringHelper;

/**
* <p>Title: TNamingStrategy</p>
* <p>Description: </p>
* <p>Copyright: Copyright (c) 2005</p>
* <p>Company: </p>
* <p>Created on 2005-5-30 </p>
* @author jinguo
* @version 1.0
*
*/

public class TNamingStrategy implements NamingStrategy {

/**
* @see net.sf.hibernate.cfg.NamingStrategy#classToTableName(java.lang.String)
*/
public String classToTableName(String className) {
return tableName(StringHelper.unqualify(className).toUpperCase());
}

/**
* @see net.sf.hibernate.cfg.NamingStrategy#propertyToColumnName(java.lang.String)
* @todo
*/
public String propertyToColumnName(String arg0) {
return null;
}

/**
* @see net.sf.hibernate.cfg.NamingStrategy#tableName(java.lang.String)
*/
public String tableName(String tableName) {
return "TBL_" + tableName.toUpperCase();
}

/**
* @see net.sf.hibernate.cfg.NamingStrategy#columnName(java.lang.String)
*/
public String columnName(String columnName) {
return "COL_" + columnName;
}

/**
* @see net.sf.hibernate.cfg.NamingStrategy#propertyToTableName(java.lang.String, java.lang.String)
* @todo
*/
public String propertyToTableName(String arg0, String arg1) {
return null;
}

}
分享到:
评论
1 楼 huihai 2016-06-07  
有demo吗?

相关推荐

    hibernate实现动态表查询的多种解决方案

    如果希望自定义这种映射规则,可以通过实现`NamingStrategy`接口来自定义命名策略。 2. **拦截器(Interceptor)**:Hibernate提供了一个非常强大的扩展点——拦截器,它可以用来拦截实体的各种生命周期事件。通过...

    HIBERNATE - 符合Java习惯的关系数据库持久化.docx

    - **NamingStrategy实现**:解释了自定义实体类和数据库表名映射的策略。 - **XML配置文件**:详述了hibernate.cfg.xml或hibernate.properties等配置文件的结构和用途。 - **J2EE集成**:讨论了在J2EE应用服务器...

    hibernate详解

    8. **NamingStrategy**:NamingStrategy允许自定义数据库表名和列名的生成规则,以适应不同的命名规范或避免名称冲突。 总之,Hibernate2为Java开发者提供了一种强大的工具,将复杂的数据库操作转换为面向对象的API...

    hibernate 帮助文档

    - **命名策略自定义**:实现自定义的`NamingStrategy`接口以调整Hibernate的表名和列名生成规则。 **3.7 XML配置文件** - **配置文件结构**:解释XML配置文件的结构和元素含义。 - **配置示例**:提供具体的配置...

    Hibernate参考文档

    NamingStrategy 定义了如何从 Java 类名转换成数据库表名等命名规则。 ##### 3.7 XML 配置文件 传统的 Hibernate 配置是通过 XML 文件完成的,虽然现在也有更多的配置选项可用。 ##### 3.8 J2EE 应用程序服务器的...

    Hibernate3.6中文文档

    - **命名策略**:实现 `NamingStrategy` 接口来自定义表名或列名。 - **XML 配置文件**:使用 XML 文件来配置 Hibernate。 - **J2EE 应用程序服务器集成**:在 J2EE 环境下使用 Hibernate。 #### 四、持久化类 - **...

    hibernate_reference

    - **3.1.6 命名策略实现**:实现`NamingStrategy`接口来自定义Hibernate如何处理表名和字段名。 - 可以覆盖默认的命名策略,使表名和字段名更加符合特定的需求。 - **3.1.7 XML配置文件**:使用XML文件来集中管理...

    hibernate教程

    ##### 3.7 实现 NamingStrategy - **命名策略**:可以自定义命名策略,控制 Hibernate 如何生成表名和字段名。 ##### 3.8 XML 配置文件 - **配置示例**:`hibernate.cfg.xml` 文件示例。 #### 四、持久化类 ##### ...

    Hibernate Service Register机制初体验

    6. **EntityResolver**: 处理类名和表名的映射,以及类的加载问题。 **五、实战经验与最佳实践** 1. **配置优化**: 根据实际项目需求,合理配置缓存策略,以提高性能。 2. **事务管理**: 正确设置事务边界,避免脏...

    Hibernate Reference Documentation

    **3.6 实现NamingStrategy** - **命名策略**:说明如何自定义Hibernate的命名策略,如表名、字段名等。 **3.7 XML配置文件** - **配置示例**:给出具体的XML配置文件示例,展示如何配置SessionFactory等。 **3.8 ...

    hibernate 3.2中文手册 中文文档

    - **3.6 实现`NamingStrategy`** - 讲解如何自定义Hibernate的命名策略,以便更好地控制字段和表名的生成。 - **3.7 XML配置文件** - 解释如何使用XML配置文件来定义Hibernate的配置信息。 - **3.8 J2EE应用程序...

    hibernate_reference使用指南全

    - **3.6 实现 NamingStrategy** 说明如何定制 Hibernate 的命名策略,以控制生成的 SQL 语句中的表名和列名。 - **3.7 XML 配置文件** 介绍如何使用 XML 文件来配置 Hibernate,这种方式较为直观且易于管理。 ...

    hibernate中文官方文档3.6

    - **实现NamingStrategy**:定义命名策略以定制Hibernate生成的SQL语句中的表名和字段名。 - **XML配置文件**:解释如何使用XML文件来配置Hibernate。 - **J2EE应用程序服务器的集成**:介绍Hibernate与J2EE应用程序...

Global site tag (gtag.js) - Google Analytics