Hibernate3 annotation many-to-one 的“高级用法”

关键的Image类
 
package amu.entity.test;

import javax.persistence.CascadeType;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;

import org.hibernate.annotations.Cache;
import org.hibernate.annotations.CacheConcurrencyStrategy;

import amu.entity.IdEntity;
import amu.entity.user.User;

/**
* @{#} Image.java Create on 2009-2-16 下午08:00:48
* <p>
*
* </p>
* @author <a href="mailto:147175882@163.com">lichengzhou</a>
* @version v 0.1
*/
@Entity
@Table(name = "IMAGES")
@Cache(usage = CacheConcurrencyStrategy.READ_WRITE)
public class Image<T> extends IdEntity {

private String path;

private Long resourceType;

private T resource;

@ManyToOne(cascade = { CascadeType.PERSIST, CascadeType.MERGE }, fetch = FetchType.LAZY)
@JoinColumn(name="RESOURCE_ID")
public T getResource() {
return resource;
}

public void setResource(T resource) {
this.resource = resource;
}

public String getPath() {
return path;
}

public void setPath(String path) {
this.path = path;
}

public Long getResourceType() {
return resourceType;
}

public void setResourceType(Long resourceType) {
this.resourceType = resourceType;
}
}


User 类的关键代码如下

@Entity
@Table(name = "USERS")
@Cache(usage = CacheConcurrencyStrategy.READ_WRITE)
public class User extends IdEntity

.......

private Set<Image<User>> images;
@OneToMany(cascade={CascadeType.PERSIST, CascadeType.MERGE})
@JoinColumn(name="RESOURCE_ID")
public Set<Image<User>> getImages() {
return images;
}

public void setImages(Set<Image<User>> images) {
this.images = images;
}
}


Role 类的关键代码如下


@Entity
@Table(name = "ROLES")
@Cache(usage = CacheConcurrencyStrategy.READ_WRITE)
public class Role extends IdEntity {

......

private Set<Image<Role>> images;
@OneToMany(cascade={CascadeType.PERSIST, CascadeType.MERGE})
@JoinColumn(name="RESOURCE_ID")
public Set<Image<Role>> getImages() {
return images;
}

public void setImages(Set<Image<Role>> images) {
this.images = images;
}
}


从上可见User和Role对Image的配置基本一致,只是在Image的泛型设置中配置了不同的值,
都可以实现和Image表的一对多(测试 是可能通过的)都能得到数据库中对映的值,但缺点也很明显,User表和Role表中如果有相同的数据,如都有ID为1的数据,那么它们都会得到相同的images集合。
如果你用的是oracle且User和Role都用的是同一个Sequence那么可以尝试下这个方法,因为两表的ID都是唯一的。

工作之余突发奇想,证实可行,但实用性不强,和大家分享下,仅供娱乐
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值