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 中如此设置: .............. name = "emali" column = "email" type = "mytype.Email" /> 在TUser.java中如此设置 public class TUser implement Serializable ...{ private Integer id; privarte Stirng name; //看,这边的 email 可以大胆的使用 List 了 private List email; //下面是一些 getter 和 setter 了 } 这样设置后你使用 TUser的时候要取出 email 直接 getEmail 出来的就是一个List 了,而且前台根本不知道后台干了什么,这样代码就简洁多了 |
|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏ICP备08020429号 )
GMT+8, 2024-9-30 03:27 , Processed in 0.201737 second(s), 12 queries , Gzip On, MemCache On.
Powered by Discuz! X3.5
© 2001-2023 Discuz! Team.