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的关系

Hibernate知识点小结(四)--JPA的更多相关文章
- Hibernate知识点小结(三)-->一对多与多对多配置
一.多表关系与多表设计 1.多表关系 一对一: 表的设计原则(分表原则): 优化表的性能 基于语意化分表 ...
- Hibernate知识点小结(二)
一.持久化对象和标识符 1.持久化类 配置完关系后,操作的实体对应的类,成为持久化类 (Customer) 2.持久化类标识符(oid:object id) 3.持久 ...
- Hibernate知识点小结(一)--快速入门
一.Hibernate的简介 1.Hibernate是一个开放源代码的对象关系映射框架 2.对象关系映射:ORM Object Relation Mapping 对象与数据 ...
- Spring知识点小结(四)
一.JdbcTemplate(jdbc模版--抽取的工具) web阶段DBUtils: QueryRunner runner = new QueryRunner(dataSource); ...
- Hibernate知识点小结汇总
Hibernate部分 1.为什么要使用Hibernate开发你的项目呢?Hibernate的开发流程是怎么样的? 为什么要使用 ①.对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复 ...
- Struts2知识点小结(四)--拦截器与注解开发
一.Struts2的拦截器(interceptor) 作用:当请求进入struts2框架后(进入之前可以用filter进行拦截),想对请求进行拦截操作(功能增强.权限控制),需要拦截器组件 1.str ...
- C++重要知识点小结---3
C++重要知识点小结---1:http://www.cnblogs.com/heyonggang/p/3246631.html C++重要知识点小结---2:http://www.cnblogs.co ...
- C++重要知识点小结---2
C++重要知识点小结--1 :http://www.cnblogs.com/heyonggang/p/3246631.html 1.C++允许程序员声明一个不能有实例对象的类,这样的类惟一的用途是被继 ...
- React及Nextjs相关知识点小结
React及Nextjs知识点小结 函数式组件和类组件区别是什么 1.函数式组件是用于创建无状态的组件,组件不会被实例化,无法访问this中的对象,无法访问生命周期方法,是无副作用的,相比于类组件函数 ...
随机推荐
- OC与JS交互之WebViewJavascriptBridge
上一篇文章介绍了通过UIWebView实现了OC与JS交互的可能性及实现的原理,并且简单的实现了一个小的示例DEMO,当然也有一部分遗留问题,使用原生实现过程比较繁琐,代码难以维护.这篇文章主要介绍下 ...
- js之闭包
函数作为返回值 高阶函数除了可以接受函数作为参数外,还可以把函数作为结果值返回. 我们来实现一个对Array的求和.通常情况下,求和的函数是这样定义的: function sum(arr) { ret ...
- 编写可维护的 Gruntfile.js
load-grunt-tasks 插件 首先介绍下 load-grunt-tasks 这个插件. 我们一般都会把所有用到的插件以及插件的配置写到 Gruntfile.js 里面,对于小项目来说这个文件 ...
- NetBeans 仿notepad++风格
一直喜欢notepad++配色跟Courier New字体.但notepad++毕竟功能有限. 改用了NetBeans,调整了下样式,终于感觉看着舒服了. 下载链接:点击下载,配置里导入就OK 风格截 ...
- flask factory
https://gist.github.com/zaccrites/c5bcf96ed90907d92042 import jinja2 from flask import Flask, render ...
- 如何批量删除Redis数据库中的Key
借助 Linux 的 xargs 指令来完成 redis-cli keys "*" | xargs redis-cli del //如果redis-cli没有设置成系统变量,需要指 ...
- SQA计划和测试规程
一.SQA计划 (一)目的 本计划的目的是定义我们该小组所做的“云医院”项目的SQA任务和职责,在项目过程中应遵循的流程.规范和约定等,以确保软件质量得到维持. (二)范围 本计划应用于“云医院”项目 ...
- SAPGUI里实现自定义的语法检查
需求:在SAPGUI里点击这个语法检查的小图标或者直接按快捷键Ctrl+F2可以执行ABAP标准的语法检查. 如果需要实现SAPGUI里自定义的语法检查,比如,某团队强制要求应用程序类的每个方法的实现 ...
- ABAP OPEN SQL里OPEN CURSOR和SELECT的比较
OPEN CURSOR After the OPEN CURSOR statement, the database cursor is positioned in front of the first ...
- 716. Max Stack (follow up questions for min stack)
Design a max stack that supports push, pop, top, peekMax and popMax. push(x) -- Push element x onto ...