一、 非主键关联,我们进行外键关联时,通常使用的是主键,但有时候需要使用到其他列时可以通过以下方法设置:
- 注解中:
@JoinColumn(name="city", referencedColumnName="CITY_Name")
其中name
属性为当前实体的属性,referencedColumnName
属性指定要关联的列 - 映射文件中: 在N方的
<many-to-one>
节点中设置一下property-ref
属性来指定列,这样就可不通过主键来关联
注意:当referencedColumnName关联到非主键列的时候,关联的目标类必须实现Serializable,还要注意的是所映射的属性对应单个列(否则映射无效).
二、只更新一被修改的字段
- 方式一:使用
updatable
,使用了该属性的字段不会再被修改
①:注解:@Column(updatable=false)
②:映射文件:<property name=”state” update=”false”></property>
缺点:不够灵活。如需要有多个字段指定不同的组合修改时不方便。 - 方式二:使用dynamic-update
①:注解:@DynamicUpdate
②:映射文件:<class name="Books" table="BOOKS" dynamic-update="true">
- 方式三:使用HQL语句。
- 方式四:跨Session实现只更新所修改的字段 ,用session.merge()方法。