首页 | 互联网 | IT动态 | IT培训 | Cisco | Windows | Linux | Java | .Net | Oracle | 软件测试 | C/C++ | 嵌入式开发 | 存储世界 | 服务器
网络设备 | IDC | 安全 | 求职招聘 | 数字网校 | 网页设计 | 平面设计 | 技术专题 | 电子书下载 | 教学视频 | 源码下载 | 搜索 | 博客 | 论坛
中国IT实验室Linux频道
中国IT教育
Google
首页 资讯动态 认证考试 新手入门 核心技术 高级技术 J2EE J2ME Java&XML 开源技术 其他技术 RSS订阅 论坛 专题
您现在的位置: 中国IT实验室 >> Java >> 开源技术 >> Hibernate >> 正文

hibernate 经验谈

    1、建立数据库的时候最好建立一个跟业务逻辑完全没有关系的id,这样的好处就是以后当数据量大的时候可以容易的建立索引,而且当业务逻辑变化的时候底层的数据结构不用变化很大。

    2、代码的干净是非常非常的重要的,从现在开始尽量让自己的代码写的漂亮把!因为干净的代码不仅容易维护,而且容易发现bug,在 hibernate 中使用 userType 是很好用的。举个经典的例子:

    实现 UserType 接口的 email 类

    比如 你需要在 TUSER 表中记录一个人的 email ,单独为其建立一张数据库表是很浪费资源的,一般的方法是将  TUSER 一栏 varchar 的来记录  email ,多个 email 之间用 " ; "  号分开,我曾经做的项目中采取的方法是:取出一个记录着多条 email 的 string  然后再来用 ; 号拆开,但是这样子就有个不好,在一堆整齐的 get 方法用出来一个有 bad smell 的代码。

    有两个方法,一个是修改映射  TUSER  的 java 类在其中增加一个 getEmail 方法,返回一个 list ,该方法对原先的 getEmail 方法进行二次处理。第二个方法就是采用  UserType 。

    UserType就是用户自定义类型,这里的类型指的是除了hibernate定义的那些类型之外的用户自己定义的。

    一个实现 UserType 接口的 email 类如下(里面的每个方法都是必须实现的接口方法,许多都可以复制粘贴的,不复杂):

 

public class Email implements UserType
...{

    // 表示本类型实例是否可变,一般是不可变
    public boolean isMutable()
   ...{
       return false;
   }

     //该类型对应的 sql 类型
     public int[] sqlTypes()
    ...{
         return new int[]......{Types.VARCHAR};
    }

     // 改类型对应的 java 类型
      public Class returnedClass()
     ...{
         return List.class;
     }

       // 完全复制的方法,由于是用户自己定义的类型,所以hibernate并不知道要如何来复制这个类,需要用户自己定义
       public Object deepCopy(Object value)  throws HibernateException
      ...{
          List source = (List)value;
          List target = new ArrayList();
          target.addAll(source);
          return target;
      }

       //equals方法,这个就不用多说了吧,肯定是要用户自定义的
        public boolean equals(Object x,Object y) throws HibernateException
      ...{
             //这部分不写出来了,自己实现吧,这个不是我要讲的重点
      }

      /** *//**//*
            这才是重头戏!nullSafeGet 和nullSafeSet 是核心所在,对数据的后期处理都在这两个方法里面
            nullSafeGet 是读取的方法
            owner 目前没用到过。
            names 是对应的数据库列名,UserType是可以对应多个列的
      */
       public Object nullSafeGet(ResultSet rs,String[] names,Object owner) throws HibernateException,SQLException
      ...{
            String value = (String)Hibernate.STRING.nullSafeGet(rs,names[0]);
            if(value != null)
            ...{
                 //把 string 拆开成 list 的代码放在这里
             }
             return resultList;//得到了拆开的 邮件列表
      }

      /**//*
            保存的方法
            index 是那个 PreparedStatement 的参数序号,一般来说不用管直接往下传
            value 就是要保存的数据,在这边是一个保存着 email 列表的 List
       */
       public void nullSafeSet(PreparedStatement st,Object value,int index) throws HibernateException,SQLException
       ...{
             if(value != null)
            ...{
                   String email = assemble(value);//将 List 拼合成 String 的 Email 的方法
                   Hibernate.STRING.nullSafeSet(st,email,index);
            }
            else
            ...{
                 Hibernate.STRING.nullSafeSet(st,value,index);
             }
       }
}


在TUser.hbm.xml 中如此设置:

 

<hibernate-mapping>
       <class name="entity.TUser" table="T_USER">
       </class>
          ..............
       <property
             name = "emali"
             column = "email"
             type = "mytype.Email"
        />
</hibernate-mapping>


在TUser.java中如此设置

public class TUser implement Serializable
...{
          private Integer id;
          privarte Stirng name;
          //看,这边的 email 可以大胆的使用 List 了
          private List email;

         //下面是一些 getter 和 setter 了
}


    这样设置后你使用 TUser的时候要取出  email 直接 getEmail 出来的就是一个List 了,而且前台根本不知道后台干了什么,这样代码就简洁多了

 

【责编:Ken】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 专题推荐

 ·关于Java框架技术专题
 ·XML全攻略技术专题
 ·JAVA开源技术介绍专题
 ·Java嵌入式开发之J2ME技术专题
 ·超前体验 Oracle 11g的5个新特性…
 ·揭密使用VB.NET的五个实用技巧
 ·Oracle和SQL Server常用函数对比专题…
 ·展现C#世界 C#程序设计专题…
 ·Java入门 Tomcat的配置技巧精华专题…
 ·Oracle RMAN物理备份技术详解…
 今日更新
 社区讨论
 博客论点
 频道精选
 Java 频道导航