组件类(嵌入式对象 )@Embeddable 注解 和Serializable接口

@embeddable是注释Java类的,表示类是嵌入类。通过此注释可以在你的Entity中使用一般的java对象,此对象需要用@Embeddable标注。

@embeddable是注释Java类的,表示类是嵌入类。
@embedded是注释属性的,表示该属性的类是嵌入类。

注意:

1.必须要实现serializable接口

2.需要有无参的构造函数

3.@Embeddable注释,表示此类可以被插入某个entity中


例子:

/**
 * Entity - 安全密钥
 */
@Embeddable
public class SafeKey implements Serializable
{
     /** 密钥 */
    private String value;

    /** 到期时间 */
    private Date expire;

    /**
     * 获取密钥
     * 
     * @return 密钥
     */
    @Column(name = "safe_key_value")
    public String getValue()
    {
        return value;
    }

    /**
     * 设置密钥
     * 
     * @param value 密钥
     */
    public void setValue(String value)
    {
        this.value = value;
    }

    /**
     * 获取到期时间
     * 
     * @return 到期时间
     */
    @Column(name = "safe_key_expire")
    public Date getExpire()
    {
        return expire;
    }

    /**
     * 设置到期时间
     * 
     * @param expire 到期时间
     */
    public void setExpire(Date expire)
    {
        this.expire = expire;
    }

    /**
     * 判断是否已过期
     * 
     * @return 是否已过期
     */
    @Transient
    public boolean hasExpired()
    {
        return getExpire() != null && new Date().after(getExpire());
    }
}
@Entity
@Table(name = "XX_table")
@SequenceGenerator(name = "sequenceGenerator", sequenceName = "t_XX_sequence")
public class Member extends BaseEntity
{
    //其他属性略

    /** 安全密匙 */
    private SafeKey safeKey; 

     /**
     * 获取安全密匙
     */
    @Embedded
    public SafeKey getSafeKey()
    {
        return safeKey;
    }

    /**
     * 设置安全密匙
     */
    public void setSafeKey(SafeKey safeKey)
    {
        this.safeKey = safeKey;
    }
}

Hibernate POJO为什么要实现Serializable接口:

转自:http://blog.csdn.net/longeremmy/article/details/7456547

实现 java.io.Serializable 接口的类是可序列化的。没有实现此接口的类将不能使它们的任一状态被序列化或逆序列化。序列化类的所有子类本身都是可序列化的。这个序列化接口没有任何方法和域,仅用于标识序列化的语意。

序列化的实现:将需要被序列化的类实现Serializable接口,该接口没有需要实现的方法,implements Serializable只是为了标注该对象是可被序列化的,然后使用一个输出流(如:FileOutputStream)来构造一个ObjectOutputStream(对象流)对象,接着,使用ObjectOutputStream对象的writeObject(Object obj)方法就可以将参数为obj的对象写出(即保存其状态),要恢复的话则用输入流。

确切的说应该是对象的序列化,一般程序在运行时,产生对象,这些对象随着程序的停止运行而消失,但如果我们想把某些对象(因为是对象,所以有各自不同的特性)保存下来,在程序终止运行后,这些对象仍然存在,可以在程序再次运行时读取这些对象的值,或者在其他程序中利用这些保存下来的对象。这种情况下就要用到对象的序列化。

只有序列化的对象才可以存储在存储设备上。为了对象的序列化而需要继承的接口也只是一个象征性的接口而已,也就是说继承这个接口说明这个对象可以被序列化了,没有其他的目的。之所以需要对象序列化,是因为有时候对象需要在网络上传输,传输的时候需要这种序列化处理,从服务器硬盘上把序列化的对象取出,然后通过网络传到客户端,再由客户端把序列化的对象读入内存,执行相应的处理。

对象序列化是java的一个特征,通过该特征可以将对象写作一组字节码,当在其他位置读到这些字节码时,可以依此创建一个新的对象,而且新对象的状态与原对象完全相同。为了实现对象序列化,要求必须能够访问类的私有变量,从而保证对象状态能够正确的得以保存和恢复。相应的,对象序列化API能够在对象重建时,将这些值还原给私有的数据成员。这是对java语言访问权限的挑战。通常用在服务器客户端的对象交换上面,另外就是在本机的存储。

对象序列化的最主要的用处就是在传递,和保存对象(object)的时候,保证对象的完整性和可传递性。譬如通过网络传输,或者把一个对象保存成一个文件的时候,要实现序列化接口 。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值