标签:
前言:不管是注解配置还是xml,都是告诉hibernate你想创建什么样的数据表,几张数据表中的关系是什么,仅此而已,剩下的不过就是hibernate的优化了。
所以从创建数据表的ddl语句和数据表的结构出发就可以很轻松地知道,hibernate需要哪些信息了。
一、xml配置
表名的配置: 用<class>标签。
属性说明:name------其值是一个Java类表示生成该Java类对应的数据表。
table-----其值表示该Java类对应的数据表的表名
lazy------值为true或false, 表示是否开启懒加载模式
说明:
关于表的字段的,约束,键值等配置的标签都是<class>标签的子节点
主键: 用<id>标签
属性:name------Java类中对应主键的属性名
column----表示该字段在数据表中的名称。
子标签:
<generator> 用于指明序列生成的方式
普通字段: 用<property>标签
说明,一般就用name和column两个属性,没有声明column时,其值就是name的值。
关系标签:
<many-to-one>
说明:
在一对多的关系中用在多方。
属性:
name-------值为该类所持有的外键引用
column-----外键名字段
cascade----设置关系的维护方式
<set> 在多对一的情况下,到一方的Java类中含有多方的集合SET通道时
属性:name----该属性指向的是该集合属性的名称。
子标签:
<key column="" /><!-- column属性是配置多方外键名 -->
<one-to-many class="" /><!--class属性值表示many方对应的Java类(注意多方含有外键)-->
注意:在默认的情况下凡是同过关系通道要想将关系的被维护方的瞬时态对象持久化----------别做梦了,除非用cascade="all"开启权限。
关于权限的设置一般在关系的维护方。
二、注解配置
注解:
注解持久化对象:@Entity
注解表名 @Table
注解主键 @Id
注解序列生成器 @SequenceGenerator(name="",sequenceName="")
@GeneratedValue(generator="")
注解字段名: @Column()
关系注解:
一对多:@OneToMany
说明:1. 该注解配置在一对多关系中的一方的集合属性上
2. 因为一方并不是外键的持有者
@ManyToOne
说明: 1. 因为多方是外键的持有者,所以对外键属性要声明:@JoinColumn(name="cid")来引入外键列
多对多:@ManyToMany()
parameter 说明:mappedBy="field which used to relate the foreign key is belong to inverseObject", 声明了该参数的Entity不能声明@JoinTable
描述: 声明了@ManyToMany()注解之后还应该声明哪些注解
维护关系通道的参数
注解通过字段声明中间表的方式:@JoinTable(name="table_name",joinColumns={@JoinColumn(name="stu_id")},inverseJoinColumns={@JoinColumn(name="cid")})
说明: 该注解主要是用来维护外键关系的
joinColumns 用来声明当前与对象所维护的外键
inverseJoinColumns to statement the foreign key which is related to inverse object
questions:
1.声明了关系型注解----对应方式,根据对应方式需要告诉hibernate哪些信息?
2.关系维护方和被维护方的权限
3.ORM模型的工作原理
4.hibernate 中的多对多,一对一,一对多等关系,其实质就是数据库中的各种关联关系,关键是如何将数据库模型转化为域模型----在转化过程中的关键点是----哪一方持有哪一方的引用
待续..........
标签:
原文地址:http://www.cnblogs.com/lightandtruth/p/5402179.html