网站大量收购独家精品文档,联系QQ:2885784924

hibernate注解详解.doc

  1. 1、本文档共16页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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)

haihang2017 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档