在SpringData JPA 中实现对持久层的操作
1.导入依赖 hibernate 这个依赖自带实现JPA接口
<dependencies><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><dependency><groupId>org.hibernate</groupId><artifactId>hibernate-entitymanager</artifactId><version>5.4.32.Final</version></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.47</version></dependency></dependencies>
2.在resources目录下建立 META-INF文件夹 ,创建JPA persistence.xml配置文件

persistence.xml
<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence" version="2.0"><!-- 需要配置persistence-unit 节点持久化单元:name: 持久化单元名称 可随时切换, 若是OpenJPA的实现方式就 换成 OpenJPA 就可以了transaction-type: 事务管理方式JTA:分布式事务管理RESOURCE_LOCAL:本地事务管理--><persistence-unit name="hibernateJPA" transaction-type="RESOURCE_LOCAL"><!--JPA 的 实现方式 顺序别搞错,要放在class上面 --><provider>org.hibernate.jpa.HibernatePersistenceProvider</provider><!--需要进行ORM 的POJO类 --><class>com.kuang.pojo.Customer</class><!-- 可选配置 :配置 JPA 实现方 的 配置信息 --><properties><!-- 数据库信息用户名 , javax.persistence.jdbc.user密码 , javax.persistence.jdbc.password驱动 , javax.persistence.jdbc.driver数据库地址 , javax.persistence.jdbc.url--><property name="javax.persistence.jdbc.user" value="root"/><property name="javax.persistence.jdbc.password" value="2001"/><property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/><property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/springdata_jpa?useUnicode=true&useSSL=false&characterEncoding=UTF-8"/><!-- 配置JPA实现方 (hibernate) 的配置信息显示sql : false|true自动创建数据库表: hibernate.hbm2ddl.autocreate: 程序运行时创建数据库表(如果有表,先删除在创建)update: 程序运行时创建表(如果有表,不会创建表)none: 不会创建表--><property name="hibernate.show_sql" value="true"/><property name="hibernate.hbm2ddl.auto" value="update"/><property name="hibernate.dialect" value="org.hibernate.dialect.MySQL57InnoDBDialect"/></properties></persistence-unit></persistence>
3.创建测试类
package com.kuang.test;import com.kuang.pojo.Customer;
import org.junit.Before;
import org.junit.Test;import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.EntityTransaction;
import javax.persistence.Persistence;
import javax.xml.soap.SAAJMetaFactory;public class JpaTest {private EntityManagerFactory factory;@Beforepublic void before() {//EntityManagerFactory 创建工厂 对应 sqlSessionFactory 用来创建 entityManagerfactory = Persistence.createEntityManagerFactory("hibernateJPA");}@Testpublic void insert() {//其实底层实现还是hibernate// entityManager 相当于 sqlSession 代码与数据库之间的桥梁EntityManager entityManager = null;EntityTransaction transaction=null;try {entityManager = factory.createEntityManager();transaction = entityManager.getTransaction();//获取事务对象transaction.begin();//事务开启Customer customer = new Customer();customer.setCustName("刘备");customer.setCustAddress("锦州");entityManager.persist(customer);transaction.commit();//事务提交} catch (Exception e) {e.printStackTrace();transaction.rollback();//事务回滚} finally {if (entityManager!=null){entityManager.close();//关闭连接}}}@Testpublic void select() {//其实底层实现还是hibernate// entityManager 相当于 sqlSession 代码与数据库之间的桥梁EntityManager entityManager = null;EntityTransaction transaction=null;try {entityManager = factory.createEntityManager();transaction = entityManager.getTransaction();//获取事务对象transaction.begin();//事务开启Customer customer = entityManager.find(Customer.class, 1L);
// Customer customer = entityManager.getReference(Customer.class, 1L);//延迟查询
// System.out.println("=======");System.out.println(customer);transaction.commit();//事务提交} catch (Exception e) {e.printStackTrace();transaction.rollback();//事务回滚} finally {if (entityManager!=null){entityManager.close();//关闭连接}}}@Testpublic void update() {//其实底层实现还是hibernate// entityManager 相当于 sqlSession 代码与数据库之间的桥梁EntityManager entityManager = null;EntityTransaction transaction=null;try {entityManager = factory.createEntityManager();transaction = entityManager.getTransaction();//获取事务对象transaction.begin();//事务开启Customer customer = new Customer();customer.setCustId(9L);customer.setCustName("lzl");customer.setCustAddress("为鲁斯");/*** 如果指定了主键:* 更新 :1. 先查询 看是否有变化* *如果有变化 更新 如果没有变化 就不更新* 如果没有指定主键:* 插入:*///存在即修改, 不存在就添加//注意: 修改是覆盖操作,你没给的值,就全给你覆盖为null// 如果你不想让他查一遍,你可以自己写JPQL语句进行添加或者修改Customer merge = entityManager.merge(customer);transaction.commit();//事务提交} catch (Exception e) {e.printStackTrace();transaction.rollback();//事务回滚} finally {if (entityManager!=null){entityManager.close();//关闭连接}}}@Testpublic void update_JPQL() {//其实底层实现还是hibernate// entityManager 相当于 sqlSession 代码与数据库之间的桥梁EntityManager entityManager = null;EntityTransaction transaction=null;try {entityManager = factory.createEntityManager();transaction = entityManager.getTransaction();//获取事务对象transaction.begin();//事务开启String jpql="update Customer set custName=:custName , custAddress=:custAddress where custId=:id";entityManager.createQuery(jpql).setParameter("custName","张杰").setParameter("custAddress","广东").setParameter("id",3L).executeUpdate();transaction.commit();//事务提交} catch (Exception e) {e.printStackTrace();transaction.rollback();//事务回滚} finally {if (entityManager!=null){entityManager.close();//关闭连接}}}@Testpublic void test_SQL() {//其实底层实现还是hibernate// entityManager 相当于 sqlSession 代码与数据库之间的桥梁EntityManager entityManager = null;EntityTransaction transaction=null;try {entityManager = factory.createEntityManager();transaction = entityManager.getTransaction();//获取事务对象transaction.begin();//事务开启String sql="update tb_customer set cust_name=:custName , cust_address=:custAddress where cust_id=:id";entityManager.createNativeQuery(sql).setParameter("custName","谢娜").setParameter("custAddress","湖南").setParameter("id",3L).executeUpdate();transaction.commit();//事务提交} catch (Exception e) {e.printStackTrace();transaction.rollback();//事务回滚} finally {if (entityManager!=null){entityManager.close();//关闭连接}}}@Testpublic void delete() {//其实底层实现还是hibernate// entityManager 相当于 sqlSession 代码与数据库之间的桥梁EntityManager entityManager = null;EntityTransaction transaction=null;try {entityManager = factory.createEntityManager();transaction = entityManager.getTransaction();//获取事务对象transaction.begin();//事务开启Customer customer = entityManager.find(Customer.class, 3L);entityManager.remove(customer);// 这样删除,是删除游离状态的,会抛异常不允许这样操作 IllegalArgumentException: Removing a detached instance com.kuang.pojo.Customer#3transaction.commit();//事务提交} catch (Exception e) {e.printStackTrace();transaction.rollback();//事务回滚} finally {if (entityManager!=null){entityManager.close();//关闭连接}}}@Testpublic void template() {//其实底层实现还是hibernate// entityManager 相当于 sqlSession 代码与数据库之间的桥梁EntityManager entityManager = null;EntityTransaction transaction=null;try {entityManager = factory.createEntityManager();transaction = entityManager.getTransaction();//获取事务对象transaction.begin();//事务开启transaction.commit();//事务提交} catch (Exception e) {e.printStackTrace();transaction.rollback();//事务回滚} finally {if (entityManager!=null){entityManager.close();//关闭连接}}}
}
相关文章:
在SpringData JPA 中实现对持久层的操作
1.导入依赖 hibernate 这个依赖自带实现JPA接口 <dependencies><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><depen…...
C++ SEH结构化异常捕获处理(双平台支持 Linux、Windows)。
测试: try_ctor();try_call([](){printf("1111111111111111111111\r\n");int* p NULL;*p 100;throw 1;// try_eeh();}, [](){printf("2222222222222222222222\r\n");}); 设置NULL指针P的值引发程式崩溃,可以被正确捕获࿰…...
jvm-sandbox-repeater 精简版部署之standalone模式
jvm-sandbox-repeater 仅仅提供了录制回放的能力,如果需要完成业务回归、实时监控、压测等平台,后面须要有一个数据中心负责采集数据的加工、存储、搜索,repeater-console提供了简单的demo示例;一个模块管理平台负责管理JVM-Sandb…...
【JavaWeb笔记】单选框,结合Servlet
各个部分的作用 jsp部分 form action"...":表单标签,供用户提交数据。内部的submit点击之后相当于是点action的URL input type"radio":输入类型为单选框。把name设置为一样的,这样效果上就是单选ÿ…...
Docker 与 Podman:揭示容器编排的最佳 25 大常见问题解答
让我们告诉你一件事。 这不仅仅是这两个强大平台之间的普通比较。 相反,我们分析并列出了有关 Docker 与 Podman 的最紧迫问题。 但这里有一件事——这些问题不仅被技术角度所包围。 我们还深入研究了业务环境,因为我们知道这不仅仅是关于代码。这是…...
Spark分布式内存计算框架
目录 一、Spark简介 (一)定义 (二)Spark和MapReduce区别 (三)Spark历史 (四)Spark特点 二、Spark生态系统 三、Spark运行架构 (一)基本概念 &#x…...
安装python第三方库后,在pycharm中不能正常导入
python小白学习opencv,使用pip安装完opencv库后import cv2报错,按照如下设置解决: 需要正确设置python解释器路径...
从“食”到“用”,燕之屋的未来增长价值几何?
12月12日,燕窝行业头部企业燕之屋在港交所上市。 作为新消费的热门赛道,近年滋补品的关注度一直比较高。“领头燕”登陆资本市场,是消费者健康养生意识不断提高,滋补品成为营养补充主流的一个积极信号。 长期以来,中…...
C++使用策略模式,减少使用switch...case...
目录 原理函数类模板函数使用switch...case...不使用switch...case... 知识点decltypestd::remove_reference 原理 函数 #include <iostream> #include <functional> #include <map>void fun1(int a, int b) {std::cout << "fun1 : a "<…...
.NET 8 编写 LiteDB vs SQLite 数据库 CRUD 接口性能测试(准备篇)
WebAppDbTest 项目准备 项目准备1、.net cli 创建项目2、nuget 包引用和项目结构2.1、项目添加相关 nuget 包2.2、WebAppDbTest 项目结构 3、项目代码说明3.1、CSharp/C# 类文件说明3.2、json 配置文件说明 4、项目运行预览 数据库 .db 文件准备1、创建 SQLite 数据库1.1、在 W…...
2024 年,新程序员如何与AI共赢!!
🌷🍁 博主猫头虎 带您 Go to New World.✨🍁 🦄 博客首页——猫头虎的博客🎐 🐳《面试题大全专栏》 文章图文并茂🦕生动形象🦖简单易学!欢迎大家来踩踩~🌺 &a…...
Debian 系统镜像下载
最近在看一些网络相关的文章需要用到 debian 11.x 的系统网上找了好多都发下载,在官网看一下 有个 11.8 的版本我无法下载,提示被最新的 debian-12.4.0 所代替,于是找到了这个链接 Index of /cdimage/unofficial/non-free/cd-including-fi…...
数据结构和算法(全)
1.了解数据结构和算法 1.1 二分查找 二分查找(Binary Search)是一种在有序数组中查找特定元素的搜索算法。它的基本思想是将数组分成两半,然后比较目标值与中间元素的大小关系,从而确定应该在左半部分还是右半部分继续查找。这个…...
Vue项目中WebSocket封装
WEBSOCKET 封装引入初始化使用 封装 utils下建立WebSocketManager.js class WebSocketManager {constructor() {this.url null;this.websocket null;this.isConnected false;this.listeners {onopen: [],onmessage: [],onclose: [],onerror: [],};this.reconnectionOptio…...
018 OpenCV 人脸检测
目录 一、环境 二、分类器原理 2.1、概述 2.2、工作原理 三、人脸检测代码 一、环境 本文使用环境为: Windows10Python 3.9.17opencv-python 4.8.0.74 二、分类器原理 CascadeClassifier是OpenCV(开源计算机视觉库)中的一个强大的类…...
Etcd实战(一)-部署etcd集群
1 概述 etcd是一个高可用的分布式键值存储系统,是CoreOS(现在隶属于Red Hat)公司开发的一个开源项目。它提供了一个简单的接口来存储和检索键值对数据,并使用Raft协议实现了分布式一致性。etcd广泛应用于Docker、Kubernetes等分布…...
Python绘制一个简单的圣诞树
在Python中,你可以使用基本的打印语句和循环来绘制一个简单的圣诞树。以下是一个例子: def draw_christmas_tree(height):for i in range(height):print( * (height - i - 1) +...
【CANoe】CANoe中使用RS232
文章目录 1、CANoe中自带示例2、示例讲解2.1CANoe自带Port A和Port B通讯2.2CANoe自带Port A和串口助手通讯 1、CANoe中自带示例 我使用的事CANoe12,RS232路径如下: C:\Users\Public\Documents\Vector\CANoe\Sample Configurations 12.0.75\IO_HIL\RS23…...
Springboot内置Tomcat线程数优化
Springboot内置Tomcat线程数优化 # 等待队列长度,默认100。队列也做缓冲池用,但也不能无限长,不但消耗内存,而且出队入队也消耗CPU server.tomcat.accept-count1000 # 最大工作线程数,默认200。(4核8g内存…...
vue+django 开发环境跨域前后端联调配置
vue环境是127.0.0.1:8080,django环境是127.0.0.1:8000 要解决url相对路径和Axios跨域权限问题。 注意:程序发起了一个 POST 请求,但请求的 URL 没有以斜杠结尾。Django 默认设置是无法执行重定向到带斜杠 URL的。例如:url http:/…...
Psins实战:从零解析SINS/GPS松组合导航中的Kalman滤波器初始化与调参
1. 初识SINS/GPS松组合导航与Kalman滤波 刚接触导航算法的朋友可能会被"SINS/GPS松组合"这个术语吓到,其实拆开看很简单。SINS(捷联惯性导航系统)就像是个不知疲倦的计步器,通过IMU(惯性测量单元)…...
大数据-253 离线数仓 - Airflow 入门与任务调度实战:DAG、Operator、Executor 部署排错指南
TL;DR 场景:面向离线数仓与定时任务场景,快速理解 Airflow 的核心概念、DAG 编排方式与基础命令。结论:本文内容适合作为 Airflow 入门示例,但代码与命令明显偏旧,需区分 Airflow 1.x 与 2.x 版本差异。产出ÿ…...
别再死记硬背了!用这5个真实运维脚本,搞定90%的Shell面试题
5个实战Shell脚本:从面试题到真实运维场景的蜕变 在技术面试中,Shell脚本能力往往是区分普通候选人和优秀候选人的关键指标。但死记硬背面试题答案的时代已经过去,现代企业更看重候选人解决实际问题的能力。本文将带你通过5个真实运维场景中的…...
告别校园网登录页!实测用UDP 53端口“曲线救国”上网的几种姿势与风险提示
校园网络优化:提升连接效率的合法实践指南 校园网络作为师生日常学习研究的重要基础设施,其稳定性和访问效率直接影响教学科研质量。许多用户在使用过程中会遇到认证页面频繁弹出、连接不稳定等问题,这通常与网络架构设计和流量管理策略有关。…...
GESP三级语法知识(六、string 入门与基础操作)
🌟 第一课:《string 入门与基础操作》🏰 第一章:string 是什么?(升级版小火车)1、🎯 故事以前我们用的是:👉 char数组 小火车 🚂(要自…...
逆向思维:用VSCode Remote+X11转发打造无缝远程Python开发环境(避坑指南)
逆向工程:VSCode Remote与X11转发的深度整合实践 远程开发环境中GUI应用的调试一直是工程师们的痛点。想象一下这样的场景:你在本地用VSCode愉快地编写着Python数据分析脚本,所有代码都在云端服务器运行,突然需要可视化一个Matpl…...
7个技巧彻底改变你的Mac菜单栏体验:Ice终极配置指南
7个技巧彻底改变你的Mac菜单栏体验:Ice终极配置指南 【免费下载链接】Ice Powerful menu bar manager for macOS 项目地址: https://gitcode.com/GitHub_Trending/ice/Ice Ice是一款强大的macOS菜单栏管理工具,专门帮助用户整理杂乱的菜单栏图标&…...
SteamShutdown:智能下载管理与自动化电源控制的创新解决方案
SteamShutdown:智能下载管理与自动化电源控制的创新解决方案 【免费下载链接】SteamShutdown Automatic shutdown after Steam download(s) has finished. 项目地址: https://gitcode.com/gh_mirrors/st/SteamShutdown 在数字娱乐时代,游戏下载已…...
计算机毕业设计springboot智能汽车租赁系统 基于SpringBoot的智慧出行车辆共享服务平台设计与实现 SpringBoot框架下城市智能租车与车辆调度管理系统开发
计算机毕业设计springboot智能汽车租赁系统 (配套有源码 程序 mysql数据库 论文) 本套源码可以在文本联xi,先看具体系统功能演示视频领取,可分享源码参考。随着城市化进程加速推进和共享经济模式蓬勃发展,传统汽车租赁行业面临运营…...
深度解析Synology Photos面部识别补丁:从技术原理到实战部署完整指南
深度解析Synology Photos面部识别补丁:从技术原理到实战部署完整指南 【免费下载链接】Synology_Photos_Face_Patch Synology Photos Facial Recognition Patch 项目地址: https://gitcode.com/gh_mirrors/sy/Synology_Photos_Face_Patch Synology Photos Fa…...
