Hibernate知识点小结(四)--JPA

一、jpa的简介和入门

JPA:Java Persistence API,接口规范
    Hinernate内部为JPA规范提供实现
    
    开发步骤(EntityManager):
        1、导入额外包:hibernate-release-5.0.7.Final\lib\jpa\hibernate-entitymanager-5.0.7.Final.jar
        2、使用jpa注解配置实体(实体与表的映射关系)
        3、配置EneityManager的核心配置文件
            在类加载路径下(src)下创建一个文件夹,名称META-INF
            在META-INF目录下创建核心配置文件 persistence.xml
        4、使用EntityManager的API对实体进行操作

二、Hibernate JPA的一对多的配置
    创建实体
    配置映射关系
        customer方:
            //当前客户有哪些联系人
            //一的一方:配置一对多,在多的一方维护外键(一的一方放弃外键维护权)
            //targetEntity:对方的字节码对象
            //mappedBy: 对方通过哪个属性与我方维护关系(mappedBy在放弃外键维护权的一方配置)
            @OneToMany(targetEntity=Linkman.class,mappedBy="customer")
            private Set<Linkman> linkmans = new HashSet<>();
        
        linkman方:
            //当前联系人属于哪一个客户
            //配置多对一
            //targetEntity:对方的字节码对象
            @ManyToOne(targetEntity=Customer.class)
            //维护外键  JoinColumn:连接字段信息(外键信息)
            //name:外键名称     referencedColumnName:与外键对应的主键名称
            @JoinColumn(name="lkm_cust_id",referencedColumnName="cust_id")
            private Customer customer;
        
    操作实体

三、Hibernate JPA的多对多的配置
    创建实体
    配置映射关系
        user方:
            //当前该用户具备哪些角色
            //配置多对多
            //targetEntity:对方的字节码对象
            //mappedBy:对方通过哪个属性与我方维护关系(放弃外键维护权的一方配置)
            @ManyToMany(targetEntity=Role.class,mappedBy="users")
            private Set<Role> roles = new HashSet<>();
        role方:
            //当前该角色被哪些用户使用
            //配置多对多
            //targetEntity:对方的字节码对象
            @ManyToMany(targetEntity=User.class)
            //User放弃外键维护权 Role去维护外键
            //配置关系
            //name:中间表的名称
            @JoinTable(
                name="sys_user_role",
                //joinColumns的name:该方(Role)在中间表中产生的外键名称
                //joinColumns的referencedColumnName:该方在中间表中产生的外键对应的主键名称
                joinColumns={@JoinColumn(name="rid",referencedColumnName="role_id")},
                //inverseJoinColumns的name:对方(User)在中间表中产生外键名称
                //inverseJoinColumns的referencedColumnName:对方(User)在中间表中产生外键对应的主键名称
                inverseJoinColumns={@JoinColumn(name="uid",referencedColumnName="user_id")}
            )
            private Set<User> users = new HashSet<>();
    操作实体

ORM-->Jpa-->Hibernate的关系

原文地址:https://www.cnblogs.com/itworkerlittlewrite/p/9451237.html

时间: 2024-08-01 01:53:23

Hibernate知识点小结(四)--JPA的相关文章

Hibernate知识点小结(二)

一.持久化对象和标识符    1.持久化类        配置完关系后,操作的实体对应的类,成为持久化类 (Customer) 2.持久化类标识符(oid:object id)        3.持久化类主键的生成策略        <id name="cust_id">            <generator class="native"></generator>                </id>    

Struts2知识点小结(四)--拦截器与注解开发

一.Struts2的拦截器(interceptor) 作用:当请求进入struts2框架后(进入之前可以用filter进行拦截),想对请求进行拦截操作(功能增强.权限控制),需要拦截器组件        1.struts2内置拦截器            1.1 struts-default.xml中配置好的拦截器            struts2框架已经定义好并使用的拦截器            发送请求 -----> interceptor1---->interceptor2 ----

SpringBoot 系列教程之事务隔离级别知识点小结

SpringBoot 系列教程之事务隔离级别知识点小结 上一篇博文介绍了声明式事务@Transactional的简单使用姿势,最文章的最后给出了这个注解的多个属性,本文将着重放在事务隔离级别的知识点上,并通过实例演示不同的事务隔离级别下,脏读.不可重复读.幻读的具体场景 I. 基础知识 在进入正文之前,先介绍一下事务隔离级别的一些基础知识点,详细内容,推荐参考博文 mysql 之锁与事务 1. 基本概念 以下基本概念源于个人理解之后,通过简单的 case 进行描述,如有问题,欢迎拍砖 更新丢失

【SpringBoot MQ 系列】RabbitMq 核心知识点小结

[MQ 系列]RabbitMq 核心知识点小结 以下内容,部分取材于官方教程,部分来源网络博主的分享,如有兴趣了解更多详细的知识点,可以在本文最后的文章列表中获取原地址 RabbitMQ 是一个基于 AMQP 协议实现的企业级消息系统,想要顺畅的玩耍的前提是得先了解它,本文将主要介绍 rabbitmq 的一些基本知识点 特点 基本概念 消息投递消费的几种姿势 事务 集群 I. 基本知识点 它是采用 Erlang 语言实现的 AMQP(Advanced Message Queued Protoco

学习IOS开发UI篇--UI知识点总结(四) UITabelView/UITableViewCell

UITabelView:常用属性 @property (nonatomic)          CGFloat    rowHeight;             // will return the default value if unset @property (nonatomic)          CGFloat     sectionHeaderHeight;   // will return the default value if unset @property (nonatom

PHP自定义框架部分知识点小结(一)

PHP自定义框架部分知识点小结(一) 网络上有大量优秀的MVC框架可供使用,但自定义框架并不是为了开发一个全面的.终极的MVC框架解决方案,而是将它看作是一个很好的从内部学习PHP的机会,在此过程中,将会学习面向对象编程和MVC设计模式,并学习到开发中的一些注意事项. Web MVC的流程体现如下图: 一个典型的Web MVC流程: Controller截获用户发出的请求: Controller调用对应的Model: Model调用DAO(基于PDO操作数据库的封装类)完成状态的读写操作: Co

(萌O(∩_∩)O)哈希知识点小结

噶呜~先来了解一下什么是哈希吧? 当我们要在一堆东西中找到想要的那一个东西,我们常常通过比较来找,理想的情况是不经过任何比较,一次就能找到,怎么才能做到这样呢?那就在记录的储存位置和他的关键字之间建立一个确定的对应关系,我们称这种对应关系为哈希函数~小盆友们应该对哈希有了一个初步的印象了吧?其实,哈希函数就是一个映像,设定很灵活,只要使任何关键字由这个哈希函数所得的哈希函数值都落在一定范围内即可.当然,不同的关键字可能得到同一哈希地址,这就出现了所谓的冲突,至于怎么解决这种冲突,稍后就会了解到.

oracle事务知识点小结

DML语句流程 1 获取事务锁和ITL2 锁定候选行3 生成redo4 生成undo5 生成redo record写入log buffer并更改数据块 事务提交1 分配SCN2 更新事务表,将事务槽状态改为0x093 回收undo块4 创建commit redo record5 将redo从log buffer刷新6 释放表锁和行锁 锁一个事务由1个TX和若干TM组成,而回滚savepoint不会释放TX锁: ITL通过XID指向事务槽,进而指向undo记录,其UBA也指向undo记录:两者区别

MySQL 视图知识点小结

视图本身是一个虚拟表,不存放任何数据.在使用SQL语句访问视图的时候,它返回的数据是MySQL从其他表中生成的.视图和表在同一个命名空间, MySQL在很多地方对于视图和表是同样对待的.不过视图和表也有不同.例如,不能在视图上创建触发器,也不能用DROP TABLE命令删除视图. 视图的实现算法: 合并算法:merge 临时表算法:tmptable 可更新视图(updatable view):可以通过更新视图来更新视图涉及的相关表. 如果视图定义中包含了group by .union.聚合函数.