Hibernate映射关系总结篇

     又从头学习了一遍hibernate的映射关系,每一次都会有新的收获,总是感觉自己还是不会hibernate。单从配置上说:知其然不知其所以然,马上就要找工作的人了,很是为自己担心呀!!

     众所周知,hibernate是一个杰出的O/R MappingObject-Relationl Mapping)框架,单从英文字面意思来解释:对象关系映射。在面向对象编程的过程中,我们往往先抽象出系统中涉及的实体对象,然后根据对象建立数据表,无疑后面对于数据库的操作是面向过程的。面向对象是简洁的,面向过程(操作数据库,写sql语句)是复杂的。Hibernate恰恰屏蔽了数据库操作这层,用户只需用面向对象的直观意识来操作数据库这更像一个facade模式,提供了对外的接口,用户只需调用接口无需知道具体实现。比如说我想获得某部门所有成员的信息,用hibernate操作一句话就搞定了session.load(Department.class, n),他的成本仅仅是从数据库load出所需的部门对象。这种方式操作数据库才是面向对象的方式,现实世界中也是这样,我想获取这个部门的所有成员,只需要知道这个部门的详细信息,因为他的成员肯定包括在详细信息中。

     但是关联关系的作用是什么呢?关联关系就是hibernate处理对象之间所参照的准则。如果你掌握好了这种规则那么hibernate会更高效的为你工作。举一个例子:

     假设我们实现一个从ParentChildren的映射:

<set name="children"><key column="pid"><one-to-many class="Child">
</set>

  当我们试图保存一个Child对象时:

Parent p = session.load(Parent.class, n);
Child c = new Child();
c...
session.save(c);
p.getChildren().add(c);
...

这样我们会得到两条sql语句一条是保存child的语句,另一条是为两者建立关系的sql语句,相当于hibernate执行了两次数据库。

让我们看一个更好的方案:

我们在child方添加配置:

<many-to-one column="parent" nou-null="rue" column="pid" />

修改parent的配置,添加inverse="true"属性,他的意思是将关联关系交给对方管理,在这就是交给了child一方管理。

下面我们再来保存一个child实例:

p.getChildren().add(c);
c.setParent(p);
session.save(c);

这样只会生成一条insert语句,至于建立两者之间关系的那条sql语句在child保存的同时已经由hibernate自动更新了,不要忘了维护child-parent之间关系的责任已经交给child一端了。相比上面的方式,我们可以发现hibernate减少了一次操作数据库的工作,这样的话相当于你的程序提高了一倍的工作效率,当然只是片面的从操作数据库数量上来说。

   单向关联关系有如下几种:具体还分为有无连接表的。双向关联关系亦有有无连接表之分。下面我们来看一下如何配置关联关系。

下面这几种是单向关联无连接表的:                                

  • Hibernate关联关系映射-----单向多对一映射配置
  • Hibernate关联关系映射-----单向一对一映射配置 
  • Hibernate关联关系映射-----单向一对多配置

下面这几种是单向关联基于连接表的:

  • Hibernate关联关系映射-----基于连接表的单向一对多映射配置
  • Hibernate关联关系映射-----基于连接表的单向一对多映射 
  • Hibernate关联关系映射-----基于连接表的单向一对一映射 
  • Hibernate关联关系映射-----基于连接表的单向多对多映射配置

下面这几种是双向关联无连接表的:

  • Hibernate关联关系映射-----双向一对多/多对一映射配置 
  • Hibernate关联关系配置-----双向一对一映射配置

下面这几种是双向关联基于连接表的:

  • Hibernate关联关系配置-----基于连接表的双向一对多/多对一映射配置
  • Hibernate关联关系配置-----基于连接表的双向一对一映射配置
  • Hibernate关联关系配置-----基于连接表的双向多对多配置







转载于:https://www.cnblogs.com/focusj/archive/2011/07/23/2136416.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/261323.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

iOS内存管理(ARC,MRC)

iOS内存管理方式&#xff1a; ARC Automatic Reference Counting 自动引用计数 MRC Manual Reference Counting 手动引用计数 更改管理方式&#xff1a; 内存管理的问题&#xff1a; 1、内存泄露&#xff1a;不再需要的对象没有释放。 2、野指针&#xff1a;正在使用的对象提前…

height:auto 火狐没边框

css高度设置为auto后&#xff0c;设置的边框 ie正常 火狐 就没有边框了&#xff0c;解决方法 之前是这样写的 #right_bottom { width: 790px; height:auto; border: #EBEBEB 1px solid; } 最后添加了一个overflow: hidden;属性ok了,ie火狐都可以显示边框 即: #right_bottom {…

mysql装完后navicat无法连接_重装mysql后导致Navicat连接失败

今天重装了mysql数据库&#xff0c;然后再使用navicat去连接数据库的时候&#xff0c;一直报错 1251 Client does not support authentication protocol requested by server解决方法&#xff1a;1、cmd登录mysql2、修改Navicat中连接数据库的密码3、刷新mysql的系统权限表flus…

【求助】小系统组成大系统所遇到的问题

以下只是举例&#xff01; 环境&#xff1a; 1&#xff0c;通用实体库CommonEntity&#xff0c;里面有管理员类 class Administrator<TEntity> : Entity<TEntity>, IAdministrator where TEntity:Administrator<TEntity>{ static TEntity Login(String usern…

Linux下提示命令找不到

摘要&#xff1a;linux&#xff0c;$PATH linux下输入某些命令时会提示&#xff1a;bash:command not found。 首先&#xff0c;查看$PATH中是否包含了这些命令。 $PATH&#xff1a;决定了shell到哪些目录中去寻找命令或程序&#xff0c;PATH值是一系列的目录。当运行程序…

怎样创建XML文档

在程序中&#xff0c;我们怎样创建一个XML文档。下面演示中&#xff0c;Insus.NET在程序创建一个和http://www.cnblogs.com/insus/p/3274220.html 一模一样的XML文档。可以在HTML markup放一个铵钮&#xff1a; 去.aspx.cs写按钮事件&#xff1a; 上图代码示例中&#xff0c;右…

UVa - 11988 Broken Keyboard(数组模拟链表)

题目链接&#xff1a;http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id18693 #include <iostream> #include <algorithm> #include <cstring> using namespace std; /**********************************************************************…

mysql黄色版_Linux机上运行多个版本的MySQL

在同一台服务器上部署多个MySQL服务&#xff0c;可以有效提高机器利用率。而且&#xff0c;将不同内容分属不同服务上&#xff0c;也相对更安全些。MySQL提供了mysqld_multi&#xff0c;但实际应用中没有人用它。弊端&#xff1a;1&#xff0c;暂停、重启&#xff0c;会导致所有…

Java实现各种排序算法

曾经学数据结构的时候&#xff0c;各种排序练的很熟&#xff0c;但是想过用Java怎么实现吗&#xff0c;以下给出来给你看看&#xff0c;当然闲着就当学习数据结构了&#xff0c;因为jdk提供的工具足够你应付所有事情。 插入排序: package org.rut.util.algorithm.support; impo…

教会你Linux Shell自动交互的三种方法

你了解Linux系统么&#xff1f;你是Linux系统的应用者么&#xff1f;如果你要学习linux&#xff0c;你可能会遇到Linux Shell自动交互问题&#xff0c;这里将介绍Linux Shell自动交互的解决方法&#xff0c;在这里拿出来和大家分享一下。 一、背景 shell脚本在处理自动循环或大…

Windows Server 2008设置远程桌面连接的最大数量

远程桌面连接的默认数量是2&#xff0c;当有多个用户需要同时远程桌面连接时很不方便&#xff0c;可以设置远程桌面连接的最大数量。 1. 运行gpedit.msc&#xff1b; 2. 选择计算机配置-->管理模板-->Windows组件-->远程桌面服务-->远程桌面会话主机-->连接&…

Navigation Drawer介绍

在2013 google IO当天&#xff0c;Android团的更新了Support库&#xff0c;新版本&#xff08;V13&#xff09;的Support库中新加入了几个比较重要的功能。 添加 DrawerLayout 控件&#xff0c;支持创建 Navigation Drawer模式。可以设置从左边划出菜单或者右边&#xff0c;也…

错误: 元素值必须为常量表达式_C语言编程常见错误集锦 【下】

1、输入数据时&#xff0c;规定精度输入数据时不能规定精度。2、switch语句中漏写break语句由于漏写了break语句&#xff0c;case只起标识的作用&#xff0c;而不起判断的作用。当grade的值为A时&#xff0c;程序会从上到下执行完&#xff0c;五个printf都输出。正确的写法应为…

asp.net上传文件时提示,不支持给定路径的格式解决方法

asp.net的上传图片&#xff0c;在部分浏览器中&#xff0c;提示”不支持给定路径的格式” 。该问题是由于浏览器的有些设置会把图片的本地完整路径发送到服务器端&#xff0c;而服务器端在写代码的时候&#xff0c;却是按单独的文件名来处理的&#xff0c;所以就导致错误。解决…

Hadoop概述

为什么80%的码农都做不了架构师&#xff1f;>>> 一&#xff1a;Hadoop的相关概念 1、Hadoop是一个基于java语言的MapReduce框架。 2、Hadoop的改进&#xff1a; a、Hadoop Streaming--任何命令行脚本都可以通过Streaming调用MapReduce框架。 b、Hadoop Hive&#xf…

mysql connection是什么_记一次MySQL出现too many connection

今天中午的时候突然接到报警,MySQL连接数暴增..本来设置的max_conntion6000, 这个数值连接已经够用.接到报警速度连接服务器连接mysql总是报如下错误:[mysqllocalhost ~]$ mysql -u xxxxx -pxxxxxxxxERROR 1040 (HY000): Too many connections本来打算kill杀掉重启搞定解决..但…

WHU 1470 Join in tasks 水题

http://acm.whu.edu.cn/land/problem/detail?problem_id1470 大概是给你一个队列,每次移动队头的数到队尾并减1,如果本身这个数为1就删去. 然后ans 这个数 * (队列长度-1),求最小的ans 只要最小的元素最先删除就能保证结果最小 解法: 先对原数列排序 然后模拟原操作 ...但是…

WebGL起步

本系列文章翻译自&#xff1a;https://developer.mozilla.org/en/WebGL 本文地址&#xff1a;https://developer.mozilla.org/en/WebGL/Getting_started_with_WebGL 翻译说明&#xff1a;水平有限并且不会逐字逐句翻译&#xff0c;只保证符合原文意思。 对于支持WebGL的浏览器来…

神奇的expect

想写自动化脚本的时候&#xff0c;遇到需要交互的&#xff0c;如ssh&#xff0c;scp&#xff0c;就束手无策&#xff0c;直到我知道了expect。 expect 有一系列expect-send对组成&#xff0c;就像聊天一样。 expect A send B expect C send D 先来个例子 #!/usr/bin/expect se…

mysql explain语句_Mysql explain 语句详解

explain 语句详解explain 写在 select 前&#xff0c;如下mysql> explain select * from user_info where id 2\G*************************** 1. row ***************************id: 1select_type: SIMPLEtable: user_infopartitions: NULLtype: constpossible_keys: PRI…