- 浏览: 166763 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (122)
- JSF (8)
- JS (4)
- CkEditor (1)
- Java (7)
- 浏览器 (1)
- 敏捷开发 (1)
- 报表 (1)
- 经典面试题 (1)
- hibernate (14)
- Web (3)
- MySQLl数据库 (1)
- 日期控件 (2)
- struts2 (1)
- SSH (1)
- Flex (1)
- MyEclipse (1)
- Exception (7)
- Tomcat (2)
- iReportJasperReports (1)
- Oracle (6)
- 数据库 (1)
- annotation (1)
- csdn (1)
- JavaMail (1)
- ITeye (1)
- ITeye论坛规则小测验key (1)
- 非技术 (6)
- 最新网络用语中文篇 (1)
- SQLException (1)
- 新浪微博 (1)
- eclipse (1)
- PrimeFaces (1)
- 权限 (2)
最新评论
-
store88:
哪里配置没注释掉呀,我发现hibernate3可以,移植到hi ...
Could not obtain connection to query metadata解决 -
灵力不足:
Struts Problem Report Struts ha ...
java.lang.NumberFormatException: For input string -
wxqhbw2008:
恩,不错的帖子
hibernate 中 get、load 的 区别 -
fileEye:
刚刚试了好多次,早点知道有答案就好了啦!
ITeye论坛规则小测验key -
tianshi1017:
DecimalFormat df = new DecimalF ...
java.text.DecimalFormat的作用是什么?如何使用?
映射实体Bean的关联关系 -Hibernate Annotations
- 博客分类:
- hibernate
3.2.0 CR1 使用@OneToOne注解可以建立实体bean之间的一对一的关联. 一对一关联有三种情况: 一是关联的实体都共享同样的主键, 二是其中一个实体通过外键关联到另一个实体的主键 (注意要模拟一对一关联必须在外键列上添加唯一约束). 三是通过关联表来保存两个实体之间的连接关系 (注意要模拟一对一关联必须在每一个外键上添加唯一约束). 首先,我们通过共享主键来进行一对一关联映射: 上面的例子通过使用注解@PrimaryKeyJoinColumn定义了一对一关联. 下面这个例子使用外键列进行实体的关联. 上面这个例子中,Customer 通过Customer 表中名为的passport_fk 外键列和 Passport关联. @JoinColumn注解定义了联接列(join column). 该注解和@Column注解有点类似, 但是多了一个名为referencedColumnName的参数. 该参数定义了所关联目标实体中的联接列. 注意,当referencedColumnName关联到非主键列的时候, 关联的目标类必须实现Serializable, 还要注意的是所映射的属性对应单个列(否则映射无效). 一对一关联可能是双向的.在双向关联中, 有且仅有一端是作为主体(owner)端存在的:主体端负责维护联接列(即更新). 对于不需要维护这种关系的从表则通过mappedBy属性进行声明. mappedBy的值指向主体的关联属性. 在上面这个例子中,mappedBy的值为 passport. 最后,不必也不能再在被关联端(owned side)定义联接列了,因为已经在主体端进行了声明. 如果在主体没有声明@JoinColumn,系统自动进行处理: 在主表(owner table)中将创建联接列, 列名为:主体的关联属性名+下划线+被关联端的主键列名. 在上面这个例子中是passport_id, 因为Customer中关联属性名为passport, Passport的主键是id. The third possibility (using an association table) is very exotic. 第三种方式也许是最另类的(通过关联表). Customer通过名为 CustomerPassports的关联表和 Passport关联; 该关联表拥有名为passport_fk的外键列,该 外键指向Passport表,该信息定义为inverseJoinColumn的属性值, 而customer_fk外键列指向Customer表, 该信息定义为 joinColumns的属性值. 这种关联可能是双向的.在双向关联中, 有且仅有一端是作为主体端存在的:主体端负责维护联接列(即更新). 对于不需要维护这种关系的从表则通过mappedBy属性进行声明. mappedBy的值指向主体的关联属性. 在上面这个例子中,mappedBy的值为 passport. 最后,不必也不能再在被关联端(owned side)定义联接列了,因为已经在主体端进行了声明. 你必须明确定义关联表名和关联列名. 在实体属性一级使用@ManyToOne注解来定义多对一关联: 其中@JoinColumn是可选的,关联字段默认值和一对一 (one to one)关联的情况相似, 列名为:主体的关联属性名+下划线+被关联端的主键列名. 在这个例子中是company_id, 因为关联的属性是company, Company的主键是id. @ManyToOne注解有一个名为targetEntity的参数, 该参数定义了目标实体名.通常不需要定义该参数, 因为在大部分情况下默认值(表示关联关系的属性类型)就可以很好的满足要求了. 不过下面这种情况下这个参数就显得有意义了:使用接口作为返回值而不是常见的实体. 对于多对一也可以通过关联表的方式来映射。 通过@JoinTable注解可定义关联表, 该关联表包含了指回实体表的外键(通过@JoinTable.joinColumns) 以及指向目标实体表的外键(通过@JoinTable.inverseJoinColumns). 你可以对 Collection ,List (指有序列表, 而不是索引列表), Map和Set这几种类型进行映射. EJB3规范定义了怎么样使用@javax.persistence.OrderBy 注解来对有序列表进行映射: 该注解接受的参数格式:用逗号隔开的(目标实体)属性名及排序指令, 如firstname asc, age desc,如果该参数为空,则默认以id对该集合进行排序. 如果某个集合在数据库中对应一个关联表(association table)的话,你不能在这个集合属性上面使用@OrderBy注解. 对于这种情况的处理方法,请参考Hibernate Annotation Extensions. EJB3 允许你利用目标实体的一个属性作为Map的key, 这个属性可以用@MapKey(name="myProperty")来声明. 如果使用@MapKey注解的时候不提供属性名, 系统默认使用目标实体的主键. map的key使用和属性相同的列:不需要为map key定义专用的列,因为map key实际上就表达了一个目标属性。 注意一旦加载,key不再和属性保持同步, 也就是说,如果你改变了该属性的值,在你的Java模型中的key不会自动更新 (请参考Hibernate Annotation Extensions). 很多人被<map>和@MapKey弄糊涂了。 其他它们有两点区别.@MapKey目前还有一些限制,详情请查看论坛或者 我们的JIRA缺陷系统。 注意一旦加载,key不再和属性保持同步, 也就是说,如果你改变了该属性的值,在你的Java模型中的key不会自动更新. (Hibernate 3中Map支持的方式在当前的发布版中还未得到支持). Hibernate将集合分以下几类. 表 2.1. 集合语义 EJB3规范不支持原始类型,核心类型,嵌入式对象的集合.但是Hibernate对此提供了支持 (详情参考 Hibernate Annotation Extensions). 上面这个例子中,City 中包括了以streetName排序的Street的集合. 而Software中包括了以codeName作为 key和以Version作为值的Map. 除非集合为generic类型,否则你需要指定targetEntity. 这个注解属性接受的参数为目标实体的class. 在属性级使用 @OneToMany注解可定义一对多关联.一对多关联可以是双向关联. 在EJB3规范中多对一这端几乎总是双向关联中的主体(owner)端, 而一对多这端的关联注解为@OneToMany( mappedBy=... ) Troop 通过troop 属性和Soldier建立了一对多的双向关联. 在mappedBy端不必也不能再定义任何物理映射 对于一对多的双向映射,如果要一对多这一端维护关联关系, 你需要删除mappedBy元素并将多对一这端的 @JoinColumn的insertable和updatable设置为false. 很明显,这种方案不会得到什么明显的优化,而且还会增加一些附加的UPDATE语句. 通过在被拥有的实体端(owned entity)增加一个外键列来实现一对多单向关联是很少见的,也是不推荐的. 我们强烈建议通过一个联接表(join table)来实现这种关联(下一节会对此进行解释). 可以通过@JoinColumn注解来描述这种单向关联关系. Customer 通过 CUST_ID列和Ticket 建立了单向关联关系. 通过联接表处理单向一对多关联是首选方式.这种关联通过@JoinTable注解来进行描述. 上面这个例子中,Trainer通过 TrainedMonkeys表和 Monkey 建立了单向关联. 其中外键trainer_id关联到Trainer (joinColumns), 而外键monkey_id关联到 Monkey (inversejoinColumns). 通过联接表来建立单向一对多关联不需要描述任何物理映射. 表名由以下三个部分组成:主表(owner table)表名+下划线+从表(the other side table)表名. 指向主表的外键名:主表表名+下划线+主表主键列名 指向从表的外键名:主表所对应实体的属性名+下划线+从表主键列名 指向从表的外键定义为唯一约束,用来表示一对多的关联关系. 上面这个例子中,Trainer和Tiger 通过联接表 Trainer_Tiger建立单向关联关系, 其中外键trainer_id关联到Trainer (主表表名, _(下划线), trainer id), 而外键trainedTigers_id关联到Tiger (属性名称, _(下划线), Tiger表的主键列名). 你可以通过@ManyToMany注解可定义的多对多关联. 同时,你也需要通过注解@JoinTable描述关联表和关联条件. 如果是双向关联,其中一段必须定义为owner,另一端必须定义为inverse(在对关联表进行更新操作时这一端将被忽略): 至此,我们已经展示了很多跟关联有关的声明定义以及属性细节. 下面我们将深入介绍@JoinTable注解,该注解定义了联接表的表名, 联接列数组(注解中定义数组的格式为{ A, B, C }), 以及inverse联接列数组. 后者是关联表中关联到Employee主键的列(the "other side"). 正如前面所示,被关联端不必也不能描述物理映射: 只需要一个简单的mappedBy参数,该参数包含了主体端的属性名,这样就绑定双方的关系. 和其他许多注解一样,在多对多关联中很多值是自动生成. 当双向多对多关联中没有定义任何物理映射时,Hibernate根据以下规则生成相应的值. 关联表名:主表表名+_下划线+从表表名, 关联到主表的外键名:主表名+_下划线+主表中的主键列名. 关联到从表的外键名:主表中用于关联的属性名+_下划线+从表的主键列名. 以上规则对于双向一对多关联同样有效. 上面这个例子中,Store_Table作为联接表. Store_id列是联接到Store表的外键. 而implantedIn_id列则联接到City表. 当双向多对多关联中没有定义任何物理映射时, Hibernate根据以下规则生成相应的值 关联表名: :主表表名+_下划线+从表表名, 关联到主表的外键名:从表用于关联的属性名+_下划线+主表中的主键列名. 关联到从表的外键名:主表用于关联的属性名+_下划线+从表的主键列名. 以上规则对于双向一对多关联同样有效. 在上面这个例子中,Store_Customer作为联接表. stores_id列是联接到Store表的外键, 而customers_id列联接到City表. 也许你已经注意到了cascade属性接受的值为CascadeType数组. 在EJB3中的cascade的概念和Hibernate中的传播性持久化以及cascade操作非常类似, 但是在语义上有细微的区别,支持的cascade类型也有点区别: 关于cascading, create/merge的语义请参考EJB3规范的6.3章节. 组合主键使用一个可嵌入的类作为主键表示,因此你需要使用@Id 和@Embeddable两个注解. 还有一种方式是使用@EmbeddedId注解.注意所依赖的类必须实现 serializable以及实现equals()/hashCode()方法. 你也可以如Mapping identifier properties一章中描述的办法使用@IdClass注解. 或者 @Embeddable 注解默认继承了其所属实体的访问类型, 除非显式使用了Hibernate的@AccessType注解(这个注解不是EJB3标准的一部分). 而@JoinColumns,即@JoinColumn数组, 定义了关联的组合外键(如果不使用缺省值的话). 显式指明referencedColumnNames是一个好的实践方式, 否则,Hibernate认为你使用的列顺序和主键声明的顺序一致. 注意上面的 referencedColumnName显式使用方式. 使用类一级的 @SecondaryTable 或 @SecondaryTables 注解可以实现单个实体到多个表的映射. 使用 @Column 或者 @JoinColumn 注解中的 table 参数可指定某个列所属的特定表. 在上面这个例子中,name保存在MainCat表中, storyPart1保存在Cat1表中, storyPart2保存在Cat2表中. Cat1表通过外键cat_id和MainCat表关联, Cat2表通过id列和MainCat表关联 (和MainCat的id列同名). 对storyPart2列还定义了唯一约束. 在JBoss EJB 3指南和Hibernate Annotations单元测试代码中还有更多的例子.Hibernate Annotations
参考文档
2.2.5. 映射实体Bean的关联关系
@Entity
public class Body {
@Id
public Long getId() { return id; }
@OneToOne(cascade = CascadeType.ALL)
@PrimaryKeyJoinColumn
public Heart getHeart() {
return heart;
}
...
}
@Entity
public class Heart {
@Id
public Long getId() { ...}
}
@Entity
public class Customer implements Serializable {
@OneToOne(cascade = CascadeType.ALL)
@JoinColumn(name="passport_fk")
public Passport getPassport() {
...
}
@Entity
public class Passport implements Serializable {
@OneToOne(mappedBy = "passport")
public Customer getOwner() {
...
}
@Entity
public class Customer implements Serializable {
@OneToOne(cascade = CascadeType.ALL)
@JoinTable(name = "CustomerPassports",
joinColumns = @JoinColumn(name="customer_fk"),
inverseJoinColumns = @JoinColumn(name="passport_fk")
)
public Passport getPassport() {
...
}
@Entity
public class Passport implements Serializable {
@OneToOne(mappedBy = "passport")
public Customer getOwner() {
...
}
@Entity()
public class Flight implements Serializable {
@ManyToOne( cascade = {CascadeType.PERSIST, CascadeType.MERGE} )
@JoinColumn(name="COMP_ID")
public Company getCompany() {
return company;
}
...
}
@Entity()
public class Flight implements Serializable {
@ManyToOne( cascade = {CascadeType.PERSIST, CascadeType.MERGE}, targetEntity=CompanyImpl.class )
@JoinColumn(name="COMP_ID")
public Company getCompany() {
return company;
}
...
}
public interface Company {
...
@Entity()
public class Flight implements Serializable {
@ManyToOne( cascade = {CascadeType.PERSIST, CascadeType.MERGE} )
@JoinTable(name="Flight_Company",
joinColumns = @JoinColumn(name="FLIGHT_ID"),
inverseJoinColumns = @JoinColumn(name="COMP_ID")
)
public Company getCompany() {
return company;
}
...
}
语义
Java实现类
注解
Bag 语义
java.util.List, java.util.Collection
@org.hibernate.annotations.CollectionOfElements 或 @OneToMany 或 @ManyToMany
List 语义
java.util.List
(@org.hibernate.annotations.CollectionOfElements 或 @OneToMany 或 @ManyToMany) 以及 @org.hibernate.annotations.IndexColumn
Set 语义
java.util.Set
@org.hibernate.annotations.CollectionOfElements 或 @OneToMany 或 @ManyToMany
Map 语义
java.util.Map
(@org.hibernate.annotations.CollectionOfElements 或 @OneToMany 或 @ManyToMany) 以及 (空 或 @org.hibernate.annotations.MapKey/MapKeyManyToMany(支持真正的map), 或 @javax.persistence.MapKey
@Entity public class City {
@OneToMany(mappedBy="city")
@OrderBy("streetName")
public List<Street> getStreets() {
return streets;
}
...
}
@Entity public class Street {
public String getStreetName() {
return streetName;
}
@ManyToOne
public City getCity() {
return city;
}
...
}
@Entity
public class Software {
@OneToMany(mappedBy="software")
@MapKey(name="codeName")
public Map<String, Version> getVersions() {
return versions;
}
...
}
@Entity
@Table(name="tbl_version")
public class Version {
public String getCodeName() {...}
@ManyToOne
public Software getSoftware() { ... }
...
}
@Entity
public class Troop {
@OneToMany(mappedBy="troop")
public Set<Soldier> getSoldiers() {
...
}
@Entity
public class Soldier {
@ManyToOne
@JoinColumn(name="troop_fk")
public Troop getTroop() {
...
}
@Entity
public class Troop {
@OneToMany
@JoinColumn(name="troop_fk") //we need to duplicate the physical information
public Set<Soldier> getSoldiers() {
...
}
@Entity
public class Soldier {
@ManyToOne
@JoinColumn(name="troop_fk", insertable=false, updatable=false)
public Troop getTroop() {
...
}
@Entity
public class Customer implements Serializable {
@OneToMany(cascade=CascadeType.ALL, fetch=FetchType.EAGER)
@JoinColumn(name="CUST_ID")
public Set<Ticket> getTickets() {
...
}
@Entity
public class Ticket implements Serializable {
... //no bidir
}
@Entity
public class Trainer {
@OneToMany
@JoinTable(
name="TrainedMonkeys",
joinColumns = @JoinColumn( name="trainer_id"),
inverseJoinColumns = @JoinColumn( name="monkey_id")
)
public Set<Monkey> getTrainedMonkeys() {
...
}
@Entity
public class Monkey {
... //no bidir
}
@Entity
public class Trainer {
@OneToMany
public Set<Tiger> getTrainedTigers() {
...
}
@Entity
public class Tiger {
... //no bidir
}
@Entity
public class Employer implements Serializable {
@ManyToMany(
targetEntity=org.hibernate.test.metadata.manytomany.Employee.class,
cascade={CascadeType.PERSIST, CascadeType.MERGE}
)
@JoinTable(
name="EMPLOYER_EMPLOYEE",
joinColumns=@JoinColumn(name="EMPER_ID"),
inverseJoinColumns=@JoinColumn(name="EMPEE_ID")
)
public Collection getEmployees() {
return employees;
}
...
}
@Entity
public class Employee implements Serializable {
@ManyToMany(
cascade = {CascadeType.PERSIST, CascadeType.MERGE},
mappedBy = "employees",
targetEntity = Employer.class
)
public Collection getEmployers() {
return employers;
}
}
@Entity
public class Store {
@ManyToMany(cascade = CascadeType.PERSIST)
public Set<City> getImplantedIn() {
...
}
}
@Entity
public class City {
... //no bidirectional relationship
}
@Entity
public class Store {
@ManyToMany(cascade = {CascadeType.PERSIST, CascadeType.MERGE})
public Set<Customer> getCustomers() {
...
}
}
@Entity
public class Customer {
@ManyToMany(mappedBy="customers")
public Set<Store> getStores() {
...
}
}
@Entity
public class RegionalArticle implements Serializable {
@Id
public RegionalArticlePk getPk() { ... }
}
@Embeddable
public class RegionalArticlePk implements Serializable { ... }
@Entity
public class RegionalArticle implements Serializable {
@EmbeddedId
public RegionalArticlePk getPk() { ... }
}
public class RegionalArticlePk implements Serializable { ... }
@Entity
public class Parent implements Serializable {
@Id
public ParentPk id;
public int age;
@OneToMany(cascade=CascadeType.ALL)
@JoinColumns ({
@JoinColumn(name="parentCivility", referencedColumnName = "isMale"),
@JoinColumn(name="parentLastName", referencedColumnName = "lastName"),
@JoinColumn(name="parentFirstName", referencedColumnName = "firstName")
})
public Set<Child> children; //unidirectional
...
}
@Entity
public class Child implements Serializable {
@Id @GeneratedValue
public Integer id;
@ManyToOne
@JoinColumns ({
@JoinColumn(name="parentCivility", referencedColumnName = "isMale"),
@JoinColumn(name="parentLastName", referencedColumnName = "lastName"),
@JoinColumn(name="parentFirstName", referencedColumnName = "firstName")
})
public Parent parent; //unidirectional
}
@Embeddable
public class ParentPk implements Serializable {
String firstName;
String lastName;
...
}
@Entity
@Table(name="MainCat")
@SecondaryTables({
@SecondaryTable(name="Cat1", pkJoinColumns={
@PrimaryKeyJoinColumn(name="cat_id", referencedColumnName="id")
),
@SecondaryTable(name="Cat2", uniqueConstraints={@UniqueConstraint(columnNames={"storyPart2"})})
})
public class Cat implements Serializable {
private Integer id;
private String name;
private String storyPart1;
private String storyPart2;
@Id @GeneratedValue
public Integer getId() {
return id;
}
public String getName() {
return name;
}
@Column(table="Cat1")
public String getStoryPart1() {
return storyPart1;
}
@Column(table="Cat2")
public String getStoryPart2() {
return storyPart2;
}
发表评论
-
org.hibernate.PersistentObjectException
2012-01-05 11:38 1059这个问题个人觉得比较奇怪,把从页面传到后台的数据组装成一个对象 ... -
Could not obtain connection to query metadata解决
2011-12-28 11:39 1644711:12:56,906 WARN JDBCEx ... -
hibernate HQL WHERE语句工具类
2011-10-21 16:40 1643package com.test; /** * ... -
DEBUG QueryTranslatorImpl:254 - unexpected query compilation problem
2011-09-25 17:12 10197:10:53,359 DEBUG QueryTrans ... -
org.hibernate.PropertyNotFoundException: no appropriate constructor in class
2011-09-25 16:04 3687hql.append("SELECT ... -
org.hibernate.QueryException: , expected in
2011-09-24 16:00 2579org.hibernate.QueryExceptio ... -
hibernate 中 get、load 的 区别
2011-09-09 01:07 1236第一篇 这次我们来谈一下Hibernate3.2 Se ... -
hibernate hql里可以new对象.
2011-08-22 18:24 3527String hql = " select ... -
Hibernate 关联关系中的OneToMany 和ManyToOne
2011-08-18 14:25 1808集合类型中的OneToMany @Entity publ ... -
如何提高hibernate性能
2011-08-08 17:26 860在一个拥有单独业务层的应用中,业务层必须在返回之前, ... -
MyEclipse从数据库反向生成实体类之Hibernate方式 反向工程
2011-08-08 17:09 1974MyEclipse从数据库反向生成实体类之Hibernat ... -
hibernate jpa 注解 @Temporal(TemporalType.DATE)
2011-08-07 12:12 25571) DATE :等于java.sql.Date 2) TIM ... -
hibernate注解
2011-08-07 11:32 1141现在EJB3实体Bean是纯粹的POJO。实际上表达了和Hi ...
相关推荐
Hibernate Annotations是Hibernate框架的一部分,它允许开发者使用Java注解来定义对象关系映射(ORM),从而简化了数据库操作。 1. **创建一个注解项目** 在开始使用Hibernate Annotations之前,你需要确保系统...
2.2.5. 映射实体Bean的关联关系 2.2.5.1. 一对一(One-to-one) 2.2.5.2. 多对一(Many-to-one) 2.2.5.3. 集合类型 2.2.5.4. 用cascading实现传播性持久化(Transitive persistence) 2.2.5.5. 关联关系获取 2.2.6. ...
无论是从简单的实体映射到复杂的关联关系管理,还是从查询优化到性能调优,Hibernate Annotations都展现出了其强大的功能和灵活性。对于开发者来说,熟练掌握这些知识点能够极大地提高开发效率,降低维护成本。
### Hibernate Annotations 中文帮助文档概览 ...同时,Hibernate 的注解机制提供了丰富的功能,如映射继承关系、复合主键等高级特性,以及内置的验证和索引支持,使得 Hibernate 成为一个强大的 ORM 工具。
Struts2、Hibernate3和Spring是Java开发中常用的三大框架,它们各自负责不同的职责:Struts2用于控制应用程序的流程,Hibernate3则是优秀的对象关系映射(ORM)框架,Spring则提供全面的依赖注入(DI)和面向切面...
文档涵盖了从创建注解项目到映射各种数据库元素、处理继承关系、映射关联、以及使用Hibernate特有的注解扩展等多个方面。 1. **创建注解项目** 在开始使用Hibernate注解时,需要满足一定的系统需求,包括Java环境...
4. **使用@ManyToOne/@OneToMany/@ManyToMany/@OneToOne**:表示实体之间的关联关系。 5. **使用@JoinColumn/@JoinTable**:进一步配置关联关系。 #### 第 3 章 通过XML覆写元数据 尽管注解提供了很大的便利性,但...
**2.2.5 映射实体关联/关系** **2.2.5.1 一对一关联** 使用 `@OneToOne` 和 `@JoinColumn` 注解来映射一对一关联。 示例: ```java @Entity @Table(name = "employee") public class Employee { @Id private ...
在本篇详细解答中,我们将深入探讨EJB 3中的实体Bean及其与数据库单表映射的关系。 首先,实体Bean是EJB的一种类型,代表业务逻辑中的持久化对象。在EJB 3中,实体Bean的实现相比之前的版本更为简化,通过注解...
标题“10_开发单表映射的实体bean”指的是在Java EE应用中,开发者针对单一数据库表创建的实体类Bean。实体Bean是Java Persistence API (JPA) 的一个重要概念,用于封装数据库中的数据对象,使得业务逻辑可以更加...
- **实体关联映射**:使用`@OneToOne`、`@ManyToOne`、`@OneToMany`和`@ManyToMany`等注解来表示实体之间的关联关系。 - **复合主键映射**:对于具有复合主键的实体,可以使用`@EmbeddedId`或`@IdClass`注解。 - **...
Hibernate Annotations 是 Hibernate 提供的一种机制,通过在 Java 类或字段上添加注解,可以方便地定义实体、属性、关系等数据库映射信息。这种方式简化了传统 XML 配置,使得代码更加清晰、易于维护。 Spring 2.0...
本文将详细介绍 Hibernate Annotations 3.5.0-Final 版本中的关键知识点,包括设置项目、实体映射、查询映射等内容。 #### 二、设置注解项目 ##### 2.1 要求 - **环境准备**:确保已安装 Java 开发工具包 (JDK),...
Hibernate Annotations 提供了一种基于注解的方式来定义这些元数据,使得对象与关系型数据库之间的映射更加直观和简洁。 #### 二、设置一个注解项目 ##### 2.1 需求 - **Java环境**:确保安装了最新版本的 JDK,...
使用@OneToOne注解建立实体Bean之间的一对一关联。一对一关联有三种情况:(1).关联的实体都共享同样的主键,(2).其中一个实体通过外键关联到另一个实体的主键(注意要模拟一对一关联必须在外键列上添加唯一约束),(3)...
在Hibernate中,实体Bean可以通过一系列的注解来定义其与数据库之间的映射关系。这些注解通常用于类级别、字段级别或方法级别。 - **`@Entity`**:此注解用于标记一个类为实体Bean,即持久化的POJO类。它告诉...
通过上述内容可以看出,Hibernate提供了丰富的注解机制来简化实体Bean的声明、属性的映射、表的定义、主键和外键的定义、关联关系的建立、查询的定义等。这些注解极大地提高了开发效率,并有助于构建清晰、灵活且...
总的来说,《Hibernate Annotations中文帮助文档》是学习和掌握Hibernate ORM框架的宝贵资源,它详细阐述了如何利用注解进行对象关系映射,以及进行数据验证和全文检索,是Java开发人员必备的参考资料。
- hibernate-core:Hibernate的核心库,包括实体管理、会话工厂等。 - hibernate-entitymanager:JPA(Java Persistence API)的支持。 - hibernate-validator:提供JSR-303/JSR-349数据校验功能。 - hibernate-...
- **hibernate-annotations.jar**:为Hibernate实体类提供了注解支持,使得ORM映射更加简洁。 - **javax.annotation-api-1.2.jar**:提供了标准的JSR-250注解,如@PostConstruct和@PreDestroy等。 - **aopalliance-...