Hibernate(三)

    xiaoxiao2022-07-02  115

    第1章 Hibernate_day03笔记

    1.1 上次课内容回顾

    Hibernate的持久化类的编写规则无参构造属性私有属性尽量使用包装类提供一个唯一OID与主键对应不要使用final修饰Hibernate的主键生成策略主键分类 自然主键代理主键 主键生成策略 incrementidentitysequenceuuidnativeassignedforeign Hibernate的持久化类的三种状态瞬时态:没有唯一标识OID,没有被session管理持久态:有唯一标识OID,已经被session管理脱管态:有唯一标识OID,没有没session管理状态转换:(了解)Hibernate的一级缓存一级缓存:HIbernate优化手段,称为是session级别缓存一级缓存:快照区Hibernate的的事务管理事务的回顾 事务的概念事务的特性引发的安全问题安全性问题解决 Hibernate解决读问题 配置设置隔离级别 Hibernate解决service事务 采用的是线程绑定的方式 Hibernate的其他APIQuery:HQL面向对象方式的查询Criteria:QBC完成面向对象化SQLQuery:SQL查询

    1.2 Hibernate的一对多的关联映射

    1.2.1 数据库表与表之间的关系

    1.2.1.1 一对多关系
    什么样的关系属于一对多 一个部门对应多个员工,一个员工只能属于某一个部门一个客户对应多个联系人,一个联系人只能属于某一个客户 一对多的建表原则:
    1.2.1.2 多对多关系
    什么样的关系属于多对多 一个学生可以选择多门课,一门课也可以被多个学生选择一个用户可以选择多个角色,一个角色也可以被多个用户选择
    1.2.1.3 一对一关系(了解)
    什么样的关系属于一对一一个公司只能有一个注册地址,一个注册地址只能被一个公司注册。

    1.2.2 Hibernate 一对多的关系配置

    1.2.2.1 创建一个项目,引入相应jar包
    1.2.2.2 创建数据库和表

    注意建表类型应为InnoDB,否则不能关联外键

    1.2.2.3 创建实体
    一的一方的实体 多的一方的实体
    1.2.2.4 创建映射文件
    多的一方的映射文件 一的一方的映射文件
    1.2.2.5 创建核心配置文件

    1.2.2.6 引入工具类
    1.2.2.7 编写测试例

    1.2.3 Hibernate 一对多的相关操作

    1.2.3.1 一对多的关系只保存一边是否可以

    1.2.3.2 一对多的级联操作
    什么叫做级联级联指的是,操作一个对象的时候,是否会同时操作器关联的对象级联是有方向性:操作一的一方的时候,是否操作到多的一方操作多的一方的时候,是否操作到一的一方
    1.2.3.3 级联保存或更新
    保存客户级联联系人 保存联系人级联联系人
    1.2.3.4 测试对象的导航

    1.2.3.5 级联删除
    级联删除:删除一边的时候,同时将另一方的数据也一并删除。删除客户级联联系人 删除联系人级联客户(基本不用)
    1.2.3.6 一对多设置了双向关联产生多余的SQL语句

    解决多余的SQL语句: 单向维护:使一方放弃外键维护 一的一方放弃。在set上配置inverse="true" 一对多的关联查询的修改的时候(CRM练习) 区分cascade和inverse

    1.3 Hibernate的多对多的关联映射

    1.3.1 Hibernate 多对多的关系配置

    1.3.1.1创建表
    用户表 角色表 中间表
    1.3.1.2 创建实体
    用户的实体 角色的实体
    1.3.1.3 创建映射
    用户的映射 角色的映射 在核心配置中添加映射wenjian
    1.3.1.4 编写测试例

    双向绑定的时候需要有一方放弃外键维护权,否则会出错,一般让被动方放弃,如,在Role.hbm.xml中set标签中添加inverse=“true”

    1.3.2 Hibernate 多对多的操作

    1.3.2.1 只保存一边是否可以

    1.3.2.2 多对多的级联保存或更新

    (与一对多的情况一致)

    保存用户级联保存角色 保存角色级联保存用户

    1.3.2.3 多对多的级联删除(基本用不上)
    删除用户级联删除角色 删除角色级联删除用户
    1.3.2.4 多对多的其他操作
    给用户选择角色 给用户改选角色 给用户删除角色
    最新回复(0)