hibernate之面向设计的细分

在Hibernate中,常常会听见:“fine-grained object model”,大致上是”适当的细粒度对象模型“;何为“适当的”?怎么才算的上是适当的,分寸的拿捏很大程度上取决与系统本身的特性,及设计者对应用逻辑的理解和项目经验的积累;何为“细粒度”?将原本业务逻辑中的对象加以细分,从而得到更加精细的对象模型(划分出更多的对象),在计算机世界中,有这样一句话:再复杂的系统,也就是由1和0组成;总而言之,对于hibernate来言,所谓的细粒度对象模型,主要针对实体类设计的对象细分,对象的细分出于2个目的:1.面向设计的粒度细分,通过对对想更精细的划分,从而更加清晰的展现系统逻辑;2.面向性能的粒度细分,针对业务逻辑,通过合理的细粒度对象,提供系统的能耗比(性能/资源消耗);

 

  • 面向设计的粒度细分
  • Component

 

对于单表的对象细分,在Hibernate中可以借助Component节点的定义完成;Component可翻译为:组件!就是从属某一整体的一个组成部分,在Hibernate中,可以根据某个实体对象中的一个逻辑组成称为Component;Component与实体对象的差别在于:Component没有标识,而实体对象有标识;因为Component是完全从属于实体对象的;

比如:一个门户网站中的用户管理,用户信息可分为:登录时所需要的帐号密码,用户的基本信息,和一些比较大型的属性如:用户的图像,个人简介还可用继续往下分)这个大的实体对象中就包含了3个逻辑组成部分:1.账户密码;2.基本信息;3.用户的大字段(图像,个人简介...)

例:TUser这样:

 

public class TUser implements java.io.Serializable {
	private static final long serialVersionUID = 1L;
	
	private Integer tId;
	private String tName;
	private String pwd;
	private TUserBase userBase;
	private TUserImg userImg;
	get()/set()
}
 

 

 

其中的将TuserBase和TuserImg分开了:TuserBase:

 

public class TUserBase implements java.io.Serializable{
	private static final long serialVersionUID = 1L;
	
	private String realName;
	private String sex;
	private String age;
        get()/set()
}

 

 TUserImg:

 

import java.sql.Blob;
import java.sql.Clob;

public class TUserImg implements java.io.Serializable{
	private static final long serialVersionUID = 1L;
	private Blob image;
	private Clob info;
        get()/set()
}

 

 写下测试类:

 

	public static void saveTest() throws Exception {
		Session session = HibernateUtil.getSessionFactory().getCurrentSession();
		session.beginTransaction();
		
		TUser tuser = new TUser();
		tuser.settName("root");
		tuser.setPwd("keith");
		
		TUserBase userBase = new TUserBase();
		userBase.setAge("21");
		userBase.setRealName("kejianjun");
		userBase.setSex("man");
		
		TUserImg userImg = new TUserImg();
		FileInputStream img = new FileInputStream("/home/keith/桌面/hankouku.jpg");
		Blob bimg = Hibernate.createBlob(img);
		userImg.setImage(bimg);
		
		Clob info = Hibernate.createClob("to many info..................");
		userImg.setInfo(info);
		
		tuser.setUserBase(userBase);
		tuser.setUserImg(userImg);
		
		session.save(tuser);
		session.getTransaction().commit();
	}

 

 看下日志文件:这是其中的建表SQL;

 

    create table TUser (
        tId integer not null auto_increment,
        tName varchar(255),
        pwd varchar(255),
        realName varchar(255),
        sex varchar(255),
        age varchar(255),
        image longblob,
        info longtext,
        primary key (tId)
    )

 

 看下添加的SQL:

 

Hibernate: insert into TUser  (tName, pwd, realName, sex, age, image, info) values  (?, ?, ?, ?, ?, ?, ?)

当然,在实际开发中并不会像上面那么设计,只是一个简单的例子而已!

  •  面向性能的粒度细分

第二个目的就是针对性能的细分,比如登录的时候,我只需要登录即可,详细信息或者是一些重量级的信息时,如果我不发送请求就不会去数据库里查询,可以提高系统的能耗比;在hibernate3中提供了延迟加载也可称为“懒加载”;

在配置文件中可以这样:

 

<property name="summary" not-null="true" length="200" lazy="true"/>

 这是hibernate文档中的例子,可以做下实验,so Easy的!

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值