我们有一些用@Column
和@Basic
注释的Hibernate getter方法。
如果我们没有相应的setter,我们会得到一个例外。为什么是这样?
在我们的例子中,我们导出从getter返回的值(以存储在DB中),并且setter没有功能目的。所以我们只有一个空方法来解决错误情况。
正如其他人所提到的,如果你注释一个属性getter方法,那么Hibernate在从数据库中读取值时会使用setter。基本上,Hibernate假定最终需要从数据库中读取写入数据库的任何内容。这意味着如果您注释一个getter,那么它需要在从数据库中读取对象时调用setter。
您可以将setter设为私有(Hibernate将使用反射来访问setter)。这是保留类的契约同时仍然使用Hibernate进行关系映射的好方法。
如果该字段是从类中的其他属性派生的,那么为什么要将它存储在数据库中?您可以使用@Transient
批注标记不应存储在数据库中的字段。您甚至可以使用@Formula
注释让Hibernate为您派生字段(它通过使用它发送到数据库的查询中的公式来实现)。
您应该使用@Entity(access = AccessType.FIELD)
注释您的类并注释您的属性。这应该可以解决您的问题。 setter是支持重构的最佳方式。那里有一个小的二传手有什么问题。
如果您不想使用setter,请设置access="field"
:
<class name="com.demo.hibernate.Country" table="country">
<id name="countryId" column="id" type="int">
<generator class="increment" />
</id>
<property name="name" column="name" access="field" type="string" />
<property name="countryCode" column="country_code" access="field" type="string" />
</class>
Hibernate使用set
方法初始化您从数据库中读取的实体。
也许,如果你创建实体字段default
或protected
或public
的访问修饰符,那么Hibernate将直接初始化字段而不使用setter(我读了一些关于它但我不确定它是否有效)。但使用setter是更优选的方式。
如果你不使用setter并使用私有属性,Hibernate必须通过反射检索Fields并执行field.setAccessible(true)。我不认为Hibernate会这样做。
我真的不知道我们是否可以告诉Hibernate这样做,但据我记得,默认配置是使用setter ...在一个集合上放置一个log / sysout,你会发现它使用了setter。