xml配置时的写法:
随着Hibernate版本的不断升级,一些内部机制也不断的在变化,老版本的Hibernate不用设置属性直接设置set、get方法就能存取数据,也就是说Hibernate实体类默认访问set、get方法。
即:持久化类中没有声明name变量,但只要有getName(),和setName()的方法存在,并且在Xyz.hbm.xml中映射过name变量
(<property name=”name” column=”NAME”/>)
,Hibernate就允许利用get和set方法从数据库中对字段NAME进行操作。但是如果在声明中加入<property name=”name” column=”NAME” access=”field”>
那么程序运行时,Hibernate就会直接访问Xyz实例所对应的持久化类的name变量属性,而不是先去访问getName()和setName()方法,如果name变量属性不存在则会抛出net.sf.hibernate.PropertyNotFoundException
异常。
【注】:显示的声明<property name=”name” column=”NAME” access=”property” />
表示不用反射机制访问实体类属性,而是显示的访问set、get方法存取数据。[老版本的Hibernate默认是access="property"
,新版本的Hibernate默认是access="field"
]
JPA注解模式的写法:
Hibernate注解模式是在3.0以后的版本出现的,但3.0之后又出了几个版本,随着版本的升级在实体类里的注解写法也有些变化,老一点儿版本的写法是@AccessType("property")
或@AccessType("field")
,而新一点儿版本的写法为@Access(AccessType.PROPERTY)
或@Access(AccessType.FIELD)
,Hibernate注解模式的默认属性是field
,这个跟xml配置的写法不一样,因为Hibernate注解模式是否有主键ID注解是有要求的。@Access(AccessType.PROPERTY)
这个注解既可以写到实体类的上面来标识整个实体类,也可以写在某一个持久化属性的上面只用来标识这一个属性。如果放在实体类上面标识实体类的时候要求这个实体类必须有主键ID的标识设置,否则加上@Access(AccessType.PROPERTY)
属性后会报错的。一般来说@Access(AccessType.PROPERTY)
注解都是写在某个持久化属性上面的,因为这样跟这个实体类是否设置主键ID没关系,一般是要在某个持久化属性的set或get方法里给其他属性做复杂处理的时候在写@Access(AccessType.PROPERTY)
注解的,也就是说要求这个持久化属性必须走set或get方法。 例如:
@Access(AccessType.PROPERTY)
private String deptype;
@Transient //代表这个属性是非持久化属性
private String pid;
public String getDeptype() {
return this.deptype;
}
public void setDeptype(String deptype) {
this.deptype = deptype;
this.pid = deptype.substring(deptype.length()-3).trim();
if("".equals(pid)) {pid = "000";}
}