在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&amp;useSSL=false&amp;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();//关闭连接}}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/211888.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CrystalDiskInfo中文版(硬盘检测工具) v9.1.1.0 绿色汉化版-供大家学习研究参考

更新内容 重新支持三星SATA SSD寿命报告 增加对ZHITAI SC001的支持 新增SK hynix Gold S31支持 增加了KLEVV NEO N610的支持。 改进的Micron/Crucial SATA SSD支持 已更改 卸载程序将显示一个确认对话框&#xff0c;用于删除设置。 强大功能 1.拥有多国语言&#xff0c;…

045:Vue读取本地上传JSON文件,导出JSON文件方法

第045个 查看专栏目录: VUE ------ element UI 专栏目标 在vue和element UI联合技术栈的操控下&#xff0c;本专栏提供行之有效的源代码示例和信息点介绍&#xff0c;做到灵活运用。 &#xff08;1&#xff09;提供vue2的一些基本操作&#xff1a;安装、引用&#xff0c;模板使…

jquery手写广告轮播图,无限循环功能

说明 在很多情况下&#xff0c;我们都需要开发广告轮播图&#xff0c;当我们进行页面的功能开发时&#xff0c;采用轮播图来实现也行&#xff0c;但是很多情况下&#xff0c;我们只需要简单的控制轮播循环轮播展示即可&#xff0c;所以用jq开开发广告轮播波&#xff0c;自定义…

Idea 插件开发: Swing Designer设计器创建的组件全部为空问题记录

问题现象 通过Swing 设计器创建的对象, Swing组件全部是空的, 导致ToolWindowFactory工厂的实现类调用时候出现了空指针异常 如下方式创建的 问题分析 问题出现时候, 同时给我生成了一个createUIComponents的私有方法, 由于个人当时理解有误, 把他当成了初始化方法, 在里面…

Oracle高可用一家老小全在这里

&#x1f4e2;&#x1f4e2;&#x1f4e2;&#x1f4e3;&#x1f4e3;&#x1f4e3; 哈喽&#xff01;大家好&#xff0c;我是【IT邦德】&#xff0c;江湖人称jeames007&#xff0c;10余年DBA及大数据工作经验 一位上进心十足的【大数据领域博主】&#xff01;&#x1f61c;&am…

用Java实现一对一聊天

目录 服务端 客户端 服务端 package 一对一用户; import java.awt.BorderLayout; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.PrintWriter; import java.net.ServerSocket; import java.net.Socket; imp…

SpringBoot中MyBatis-Flex的集成和使用

一、MyBatis-Flex 是什么​ MyBatis-Flex是一个基于MyBatis的数据访问框架&#xff0c;专门为Flex应用程序而设计的。它提供了一种灵活而高效的方式来处理Flex应用程序中的数据访问&#xff0c;可以轻松地连接到各种数据源&#xff0c;并提供了一些方便的工具和功能&#xff0c…

delphi android打开外部文件,报错android.os.FileUriExposedException解决方法

Android 7.0强制启用了被称作 StrictMode的策略&#xff0c;带来的影响就是你的App对外无法暴露file://类型的URI了。 如果你使用Intent携带这样的URI去打开外部App(比如&#xff1a;打开系统相机拍照)&#xff0c;那么会抛出FileUriExposedException异常。 Delphi 为Android…

windows系统安装RocketMQ_dashboard

1.下载源码 按照官网说明下载源码 官网 官网文档 2.源码安装 2.1.① 编译rocketmq-dashboard 注释掉报错的maven插件frontend-maven-plugin、maven-antrun-plugin mvn clean package -Dmaven.test.skiptrue2.2.② 运行rocketmq-dashboard java -jar target/rocketmq-…

tamcat乱码

学习springmvc时tamcat乱码 ①、启动时tomcat控制台乱码 解决方法是&#xff1a;1、先把idea设置里的默认字节码改成utf-8 ​ 2、把idea显示编码改成utf-8&#xff0c;在末尾加上&#xff08; -Dfile.encodingUTF-8&#xff09; ​ 3、最后重启idea 加上这个 -Dfile.encodingU…

【软考中级——软件设计师】备战经验 笔记总结分享

考试成绩 我第一次备考是在2022 然后那时候取消了这次是第二次 靠前我一个月复习的看了以前的笔记 然后刷了七八道历年题目学习资料推荐 &#xff1a;zst——2021 b站链接自荐一下我的笔记 &#xff1a; 软考笔记专栏 视频确实很长 &#xff0c; 我的建议就是先看笔记 然后不会…

1-2、Java环境搭建

语雀原文链接 文章目录 1、JDK安装2、Hello World2-1、Hello World示例2-2、类名和文件名2-3、注释2-4、javadoc 3、环境变量3-1、Path作用3-2、classpath3-3、JAVA_HOME 4、Java组成5、跨平台原理5-1、Java跨平台原理5-2、C语言的跨平台原理 1、JDK安装 下载地址&#xff1a…

打造Github首页的动态飞线效果

一、导语 Github首页的地球动态飞线&#xff0c;大家都比较熟悉吧 二、分析 由大量随机的3点构造出贝塞尔曲线&#xff0c;然后开始从起点到终点的飞行后&#xff0c;然后再从起点到终点的消失&#xff0c;就此完成整个过程 三、基础代码 createCurve(startPoint, endPoint…

unity 2d 入门 飞翔小鸟 死亡闪烁特效(十三)

一、c#脚本 using System.Collections; using System.Collections.Generic; using UnityEngine;public class Bling : MonoBehaviour {public Texture img;public float speed;public static bool changeWhite false;private float alpha0f;// Start is called before the fi…

芯片量产导入知识

什么是芯片量产 从芯片功能设计到生产制造、测试等环节&#xff0c;每一个环节都至关重要。 对于保障大规模发货后芯片指标表现的一致性&#xff0c;以及产品应用生命周期内的稳定性和可靠性&#xff0c;需要考虑多种因素。以下是一些相关的观点&#xff1a; 可量产性设计&am…

Stable Diffusion 系列教程 - 2 WebUI 参数详解

Stable Diffusion 的整个算法组合为&#xff1a; UNet VAE 文本编码器 UNet&#xff1a;就是我们大模型里的核心。 文本编码器&#xff1a;将我们的prompt进行encoder为算法能理解的内容&#xff08;可以理解为SD外包出去的项目CLIP&#xff09;。 VAE&#xff1a;对UNet生…

【牛牛送书 | 第三期】《一本书讲透Java线程:原理与实践》带你深入JAVA多线程

目录 摘要&#xff1a; 多线程对于Java的意义 为什么Java工程师必须掌握多线程 Java多线程使用方式 如何学好Java多线程 参与方式&#x1f947; 摘要&#xff1a; 互联网的每一个角落&#xff0c;无论是大型电商平台的秒杀活动&#xff0c;社交平台的实时消息推送&#x…

Qt槽函数不响应不执行的一种原因:ui提升导致重名

背景&#xff1a; 一个包含了组件提升的ui&#xff0c;有个按钮的槽函数就是不响应&#xff0c;于是找原因。 分析&#xff1a; 槽函数的对应一是通过connect函数绑定信号&#xff0c;二是on_XXX_signal的命名方式。界面上部件的槽函数通常是第二种。 我反复确认细节&#…

张正友相机标定法原理与实现

张正友相机标定法是张正友教授1998年提出的单平面棋盘格的相机标定方法。传统标定法的标定板是需要三维的,需要非常精确,这很难制作,而张正友教授提出的方法介于传统标定法和自标定法之间,但克服了传统标定法需要的高精度标定物的缺点,而仅需使用一个打印出来的棋盘格就可…

kafka学习笔记--如何保证生产者数据可靠、不重复、有序

本文内容来自尚硅谷B站公开教学视频&#xff0c;仅做个人总结、学习、复习使用&#xff0c;任何对此文章的引用&#xff0c;应当说明源出处为尚硅谷&#xff0c;不得用于商业用途。 如有侵权、联系速删 视频教程链接&#xff1a;【尚硅谷】Kafka3.x教程&#xff08;从入门到调优…