@经常使用属性说明:

    @Entity:实体类

    @Table:指定相应数据表

    @Id:主键,使用能够为null值的类型,假设实体类没有保存到数据库是一个暂时状态

    @Column:配置普通属性,除了主键外,java基本类型的属性

    @Base:普通属性的载入方式

    @GeneratedValue:主键生成策略

    @Temporal:日期类型(DATE,TIME还是TIMESTAMP),假设属性类型是java.util.Date(是以上3个类的父类)类型时才须要使用该@声明详细的日期类型

    @Transient:暂时属性

    @Version:版本号属性,配置乐观锁



hibernate实体关联映射:

    一对一单向:

        一段:还有一端实体属性:@OneToOne(cascade),@JoinColumn(name=外键名,unique=true)

        还有一端:

        一段数据库:还有一端实体的外键:表名_id

        还有一端数据库:

    一对一双向:

        一段:还有一端实体属性:@OneToOne(cascade),@JoinColumn(name=外键名,unique=true)

        还有一端:还有一端实体属性:@OneToOne(mappedBy=还有一端属性名)

        一段数据库:还有一端实体的外键:表名_id

        还有一端数据库:

    一对一双向(主键):

        一段:@Id,@GeneratedValue,还有一端实体属性:@OneToOne,@PrimaryKeyJoinColumn

        还有一端:@Id,不能使用@GeneratedValue(与还有一端使用同样主键),还有一端实体属性:@OneToOne,@PrimaryKeyJoinColumn

        一段数据库:没有关联,依据主键推断

        还有一端数据库:没有关联,依据主键推断

    一对多单向:

        一段:多端实体集合属性:@OneToMany(fetch,cascade,targetEntity(使用范型能够省略)),@JoinColumns(value={@JoinColumn(name="外键名"),referencedColumnName="还有一端id"})

        多端:

        一段数据库:

        多端数据库:一段实体的外键:表名_id

    多对一单向:

        一段:

        多端:一段实体属性:@ManyToOne(CascadeType,fetch),@JoinColumn(外键名)

        一段数据库:

        多端数据库:一段实体的外键:表名_id

    一对多双向(多对一双向):

        一段:多端实体集合属性:@OneToMany(mappedBy="多端实体类中的一段属性名")

        多端:一段实体属性:@ManyToOne(fetch,cascadeType),@JoinColumn(外键名)

        一段数据库:

        多端数据库:一段实体的外键:表名_id

    多对多单向:

        多段:还有一端实体集合属性:@ManyToMany(fetch,cascade,),@JoinTable(name,JoinColumns,inverseJoinColumns)

        还有一多端:

        多段数据库:

        还有一端端数据库:

        中间表(表1_表2):外键1:表1_id,外键2:表2_id

    多对多双向:

        多段:还有一端实体集合属性:@ManyToMany(fetch,cascade,),@JoinTable(name,JoinColumns,inverseJoinColumns)

        还有一多端:@ManyToMany(mappedBy=还有一多端实体集合属性名)

        多段数据库:

        还有一端端数据库:

        中间表(表1_表2):外键1:表1_id,外键2:表2_id





1 双边关系中,控制权一般交给多端,由mappedBy指定,配置信息要到多端找

2 mappedBy把控制权交给还有一端(还有一端中的属性名),还有一端配置同单向配置全然同样

3 多对多属性必须使用@JoinTable指定中间表的配置,当中name指定表名,joinColumns指定该表与中间表的相应关系,inverseJoinColumns指定还有一端与中间表的关系

4 mappedBy表示该属性是反向属性,与还有一端实体类的指定的属性相应

5 Map映射:集合属性能够使用Map类型,Map使用索引-值属性对,速度快,配置时跟@OneToMany,@ManyToMany一样,仅仅需再添加�@MapKey就可以,如:

    @MapKey(name = "name")//配置数据库列名,使用该字段索引数据

    private Map<String,Student> students = new new HashSet<String,Student>();

hibernate 实体关系映射笔记的更多相关文章

  1. Hibernate实体关系映射(OneToMany单边)——完整实例

    单边一对多关系:电子邮件管理 单边一对多关系:指一方有集合属性,包含多个多方,而多的一方没有一方的引用. 比如:用户(一)与电子邮件(多).一个用户可以有多个电子邮件记录. 目的:通过OneToMan ...

  2. Hibernate实体关系映射(OneToMany、ManyToOne双边)——完整实例

    双边关系是最常见的配置.在多方有一方的引用,一方也有多方的引用.双边关系能够很方便地查询数据.看一个班级与学生的双边关系. 班级(Clazz类)与学生(Student类):一对多关系.班级中有学生属性 ...

  3. hibernate(3) —— 关系映射

    hibernate中关系映射指的是实体类与实体类间的关系.和数据库中表与表之间的关系类似,有一对一,多对一,一对多,多对多四种映射关系. 一:一对一映射 两个对象之间是一对一的关系,如人和身份证之间是 ...

  4. Java IDE 编辑器 --- IntelliJ IDEA 进阶篇 生成 hibernate 实体与映射文件

    原文:转:Java IDE 编辑器 --- IntelliJ IDEA 进阶篇 生成 hibernate 实体与映射文件 2011-04-30 12:50 很多人不知道怎么用 IntelliJ IDE ...

  5. JPA实体关系映射:@ManyToMany多对多关系、@OneToMany@ManyToOne一对多多对一关系和@OneToOne的深度实例解析

    JPA实体关系映射:@ManyToMany多对多关系.@OneToMany@ManyToOne一对多多对一关系和@OneToOne的深度实例解析 今天程序中遇到的错误一 org.hibernate.A ...

  6. Hibernate注解关系映射

    Hibernate Annotation关系映射的几种类型映射用法及使用方法(说明:以前实例的实体是user和role,主键分别是userid和roleid)   1)一对一外键关联映射(单向) @O ...

  7. [刘阳Java]_MyBatis_实体关系映射_第8讲

    MyBatis既然是一个ORM框架,则它也有像Hibernate那样的一对多,多对多,多对一的实体关系映射功能.下面我们就来介绍一下如何使用MyBatis的实体关系映射 1.MyBatis实体关系映射 ...

  8. OrchardNoCMS实体关系映射扩展

    在OrchardNoCMS中,默认的系统会把实体关系映射保存到mappings.bin文件中. 如果不进行任何修改,默认的可以自动保存关系映射的model是有很大限制的. 条件是model的命名空间必 ...

  9. JPA总结——实体关系映射(一对多@OneToMany)

    JPA总结——实体关系映射(一对多@OneToMany) 注意:本文出自“阿飞”的博客,如果要转载本文章,请与作者联系! 并注明来源: http://blog.sina.com.cn/s/blog_4 ...

随机推荐

  1. hihoCoder 1385 A Simple Job

    #1385 : A Simple Job 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 Institute of Computational Linguistics (I ...

  2. hdu 2059(dp)

    题意:容易理解... 思路:dp[i]表示乌龟到达第i个充电站时最少花费时间到第 i 个充电站后,从起点开始遍历到第 i-1 个充电站,得到最少花费时间 状态转移方程:dp[i]=min(dp[j]+ ...

  3. MyBatis批量删除 多态sql,构建in语句

    <!--==========================删除==================================== -->    <delete id=&quo ...

  4. UE 使用技巧

    一.关于正则表达式的使用 删除空行: 替换 %[ ^t]++^p 为 空串 替换回车换行符:替换^p 为 空串 删除行尾空格: 替换 [ ^t]+$ 为 空串 删除行首空格: 替换 %[ ^t]+ 为 ...

  5. CodeForces 558E(计数排序+线段树优化)

    题意:一个长度为n的字符串(只包含26个小字母)有q次操作 对于每次操作 给一个区间 和k k为1把该区间的字符不降序排序 k为0把该区间的字符不升序排序 求q次操作后所得字符串 思路: 该题数据规模 ...

  6. SDUT 3568 Rock Paper Scissors 状压统计

    就是改成把一个字符串改成三进制状压,然后分成前5位,后5位统计, 然后直接统计 f[i][j][k]代表,后5局状压为k的,前5局比和j状态比输了5局的有多少个人 复杂度是O(T*30000*25*m ...

  7. 对象指针与this指针

    对象指针分为三大类 [1]指向对象的指针 [2]指向对象成员的指针(数据类) [3]指向对象成员的指针(函数类) #include<iostream> using namespace st ...

  8. 你认为你很了解Javascript?

    (翻译不当之处请谅解) 来源:http://www.ido321.com/914.html 这里有5个小脚本,有助于你真正理解JavaScript核心–闭包和作用域.没有在控制台运行之前,尝试回答每个 ...

  9. jQuery Mobile入门教程

    简介:jQuery Mobile框架可以轻松的帮助我们实现非常好看的.可跨设备的Web应用程序.我们将后续的介绍中向大家介绍大量的代码及实例. jQuery一直以来都是非常流行的富客户端及Web应用程 ...

  10. 【暑假】[实用数据结构]UVa11995 I Can Guess the Data Structure!

    UVa11995  I Can Guess the Data Structure! 思路:边读边模拟,注意empty的判断! 代码如下: #include<iostream> #inclu ...