- 1、本文档共16页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
hibernate注解详解
@Table?Table用来定义entity主表的name,catalog,schema等属性。?属性说明:?
name:表名
catalog:对应关系数据库中的catalog
schema:对应关系数据库中的schema
UniqueConstraints:定义一个UniqueConstraint数组,指定需要建唯一约束的列
Java代码??
@Entity??
@Table(name=CUST)??
public?class?Customer?{?...?}??
@SecondaryTable?一个entity class可以映射到多表,SecondaryTable用来定义单个从表的名字,主键名字等属性。?属性说明:?
name:表名
catalog:对应关系数据库中的catalog
pkJoin:定义一个PrimaryKeyJoinColumn数组,指定从表的主键列
UniqueConstraints:定义一个UniqueConstraint数组,指定需要建唯一约束的列
下面的代码说明Customer类映射到两个表,主表名是CUSTOMER,从表名是CUST_DETAIL,从表的主键列和主表的主键列类型相同,列名为CUST_ID。?
Java代码??
@Entity??
@Table(name=CUSTOMER)??
@SecondaryTable(name=CUST_DETAIL,pkJoin=@PrimaryKeyJoinColumn(name=CUST_ID))??
public?class?Customer?{?...?}??
@SecondaryTables?当一个entity class映射到一个主表和多个从表时,用SecondaryTables来定义各个从表的属性。?属性说明:?
value:定义一个SecondaryTable数组,指定每个从表的属性。
Java代码??
@Table(name?=?CUSTOMER)??
@SecondaryTables(?value?=?{??
@SecondaryTable(name?=?CUST_NAME,?pkJoin?=?{?@PrimaryKeyJoinColumn(name?=?STMO_ID,?referencedColumnName?=?id)?}),??
@SecondaryTable(name?=?CUST_ADDRESS,?pkJoin?=?{?@PrimaryKeyJoinColumn(name?=?STMO_ID,?referencedColumnName?=?id)?})?})??
public?class?Customer?{}??
@UniqueConstraint?UniqueConstraint定义在Table或SecondaryTable元数据里,用来指定建表时需要建唯一约束的列。?属性说明:?
columnNames:定义一个字符串数组,指定要建唯一约束的列名。
Java代码??
@Entity??
@Table(name=EMPLOYEE,uniqueConstraints={@UniqueConstraint(columnNames={EMP_ID,?EMP_NAME})})??
public?class?Employee?{?...?}??
@Column?Column元数据定义了映射到数据库的列的所有属性:列名,是否唯一,是否允许为空,是否允许更新等。?属性说明:?
unique:是否唯一
nullable:是否允许为空
insertable:是否允许插入
updatable:是否允许更新
columnDefinition:定义建表时创建此列的DDL
secondaryTable:从表名。如果此列不建在主表上(默认建在主表),该属性定义该列所在从表的名字。
Java代码??
public?class?Person?{??
????@Column(name?=?PERSONNAME,?unique?=?true,?nullable?=?false,?updatable?=?true)??
????private?String?name;??
????@Column(name?=?PHOTO,?columnDefinition?=?BLOB?NOT?NULL,?secondaryTable=PER_PHOTO)??
????private?byte[]?picture;??
@JoinColumn?如果在entity class的field上定义了关系(one2one或one2many等),我们通过Joi
文档评论(0)