Hibernate-关系映射
1.为什么用Hibernate框架:
java程序数据保存的变化:
* 内存存在:java基础中,
数据保存在内存中,只在内存中暂时存在
* 文件保存:有io/流之后,数据可以保存到文件中
* 数据库保存:随着数据量的增大,数据处理变多,
如果继续保存到文件,保存和解析存在格式问题,工作量大,并且重复性高,操作繁琐并且与程序功能关系小,
出现了数据库,对于大量数据的保存和操作都比较节约资源
* jdbc连接数据库:jdbc连接数据库,虽然数据可以保存,但每个操作都有数据库的连接,数据的读取,再解析数据转化为对象,代码重复多
* Hibernate框架:框架就是模板/模型,它把java中从数据库读数据,转化为对象供程序使用的常用代码做成一个工具黑箱,
即对jdbc进行轻量级封装,不需要关心数据库表数据是如何变成对象的,我们只要设置好对应的映射关系,
告诉框架我们是要取对象还是操作对象,框架自动帮我们把这些机械劳动做完,让我们把更多的精力放在程序运行设计上
2.当类之间存在包含关系,怎么在映射里体现?
常用关系映射有四种:
1.单向一对多:
a.实体类:在一的一方添加set集合,泛型指定为多的一方类
private Set jds = new HashSet();
b.映射文件:添加<set>
<set name="jds" > //指定本类set的属性名
<key column="qxid" /> //会在多的一方添加该列
<one-to-many class="Jd" /> //绑定多的一方的类
</set>
2.单向多对一
a.实体类:添加一的一方的类属性
private Qx qx;
b.映射文件:添加<many-to-one>
<many-to-one name="qx" class="Qx" column="qxid" /> //在本类添加该列
指定本类要关联的属性-->指定关联的类-->指定关联的列,会在本类添加
3.多对多:
a.实体类:双方添加set
b.映射文件:就一方而言,每一方都按多对一配置即可
<set name="members" table="r_emp_proj"> //双方都有多个,需要建一个中间表来保存对应关系
<key column="r_proj_id" /> //指定本类关联的列,对方列
<many-to-many
class="com.zhaolong.entity.Employee" column="r_emp_id" /> //指定关联的类和指定关联列
</set>
<set name="projects" table="r_emp_proj" inverse="true"> //有一方放弃列的管理(理解为主键生成的权力)
<key column="r_emp_id" />
<many-to-many
class="com.zhaolong.entity.Project" column="r_proj_id" />
</set> 4.一对一:
a.实体类:添加一的一方的类属性
private Qx qx;
b.映射表:双方添加<one-to-one>
<one-to-one name="card" class="对方类全限定名" />
总结:书写时,先指定本方是用什么关联? 再书写关联的是什么? 用那个列来关联?
多对一和一对多,也可以双向关联,看具体情况,比如从本方查对方数据,就要双向关联
3.inverse cascade 怎么用?
都是在one,many标签中用,inverse为在关联中放弃生成主键权力,cascade为指定在执行何种操作时进行级联,同步删除或更新
Hibernate-关系映射的更多相关文章
- Hibernate学习笔记-Hibernate关系映射
1. 初识Hibernate——关系映射 http://blog.csdn.net/laner0515/article/details/12905711 2. Hibernate 笔记8 关系映射1( ...
- 【SSH 基础】浅谈Hibernate关系映射(4)
继上篇博客 多对多关联映射(单向) 多对多对象关系映射,须要增加一张新表完毕基本映射. Hibernate会自己主动生成中间表 Hibernate使用many-to-many标签来表示多对多的关联,多 ...
- web进修之—Hibernate 关系映射(3)
概述 Hibernate的关系映射是Hibernate使用的难点或者是重点(别担心,不考试哦~),按照不同的分类方式可以对这些映射关系做一个分类,如: 按对象对应关系分: 一对一 多对一/一对多 多对 ...
- Hibernate关系映射时出现的问题
在学习Hibernate框架的关系映射时,遇到了一个问题: INFO: HHH000422: Disabling contextual LOB creation as connection was n ...
- Hibernate关系映射之many-to-many
1.建表 2.创建实体类及映射文件 Student.java类 public class Student implements java.io.Serializable { // Fields pri ...
- hibernate关系映射
多对一:比如多个订单对应同一个用户,需要在订单表中添加一个用户的属性 订单类: private Integer orderId; private Date createTime; private Us ...
- Hibernate关系映射(注解)
1.类级别注解 @Entity 映射实体类 @Table 映射数句库表 @Entity(name="tableName") - 必须,注解将一个类声明为一个实体bea ...
- Hibernate关系映射(三) 多对多
一.使用用户User和Role实现多对多的示例 User.java,实现对Role的引用 package com.lxit.entity; import java.util.HashSet; impo ...
- Hibernate关系映射(三) 多对一和一对多
一.多对一 学生Student和班级Grade实现多对一,多个学生对应一个班级. Student.java实体类,映射了班级的属性. package com.lxit.entity; import j ...
- Hibernate关系映射(二) 基于外键的双向一对一
基于外键的双向一对一关联映射 需要在一端添加<one-to-one>标签,用property-ref来指定反向属性引用. 还是通过刚才用户和地址来演示双向一对一关联. 代码演示 一.实体类 ...
随机推荐
- postgresql+postgis+pgrouting实现最短路径查询(2)---openlayers+geoserver实现最短路径
自己的最短路径实现基本上是按照参考博文的1.2和3进行的,实现的时候也是问题不断,只能是一个一个解决. 问题1:自己发布的geoserver服务无法和OSM底图叠加到一起. 解决:参考博文2提到发布服 ...
- hdu-3388 Coprime---容斥定理&&DFS版
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3388 题目大意: 求同时与m,n互质的第k个数是多少! 解题思路: 和HDU-4135类似,将m和n ...
- POJ-1284 Primitive Roots---原根&欧拉函数
题目链接: https://cn.vjudge.net/problem/POJ-1284 题目大意: 就是给出一个奇素数,求出他的原根的个数. 解题思路: 由于是m是奇素数,m的欧拉函数值为m - 1 ...
- NGSQC toolkit
一.NGSQCTooklit 使用 主要是去除dapter和低质量的碱基,并有统计结果 可以得到如下的结果 1,每个位置的碱基的平均质量 2,每个GC值对应的reads数 3,每个质量值对应的read ...
- rc.local 开机自启脚本无法启动
1.看是否rc.local 第一行如果是 #!/bin/sh -e 改成 #!/bin/bash sudo systemctl enable rc-local.service 2.看rc.local的 ...
- PHP----作业:查询数据显示在页面上
作业: 查询INFO表所有数据,显示在页面上(表格)性别要显示男女 民族 显示民族名称 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Tra ...
- 17、配置嵌入式servlet容器(1)
SpringBoot默认使用Tomcat作为嵌入式的Servlet容器 1).如何定制和修改Servlet容器的相关配置 1.修改和server有关的配置 (Se ...
- 我的第一个C++程序
准备抽空学习C++了,不知道自己以后能不能坚持下去,去百度查了一下入门,大多数朋友都是选择用VC++或者VS,而我这里用的是C-Free 5 ,安装包也只有十几兆. 用起来也方便.对于初学者而言够用了 ...
- jQuery中append()、prepend()与after()、before()的区别
转载 未曾见海 https://www.cnblogs.com/afei-qwerty/p/6682963.html 在jQuery中,添加元素有append(),prepend() 和 after ...
- PAT——1011. A+B和C
给定区间[-231, 231]内的3个整数A.B和C,请判断A+B是否大于C. 输入格式: 输入第1行给出正整数T(<=10),是测试用例的个数.随后给出T组测试用例,每组占一行,顺序给出A.B ...