Service层控制事务

article/2025/9/23 18:12:47

1.Service业务逻辑层:


1.业务概述:
代表用户完成的一个业务功能,可以由一个或多个DAO的调用组成。(软件所提供的一个功能都叫业务)


2.Service开发流程
在这里插入图片描述

2.事务:


在JDBC中,在Service层实现事务需要以下几个步骤:
获得Connection对象开始事务–提交或回滚–关闭连接。其事务策略是

  1. 获得Connection对象开始事务:
    connection.setAutoCommit(false);//true等价于1,false等价于0,将自动提交事务改为手动提交事务
  2. 提交或回滚
    connection.commit();//手动提交事务
    connection.rollback();//手动回滚事务
  3. 关闭连接
    connection.close()

3.问题:


对于Service层获得的数据库连接,其与DAO层所获得的数据库连接直接操作数据库的连接并不相同,所以Service层数据库连接提交或回滚并不影响DAO层的数据库连接!!!

4.问题解决办法:


1.解决方案1:传递Connection
为了解决线程中Connection对象不同步的问题,可以将Connection对象通过service传递给各个DAO方法,实现Service层数据库连接与DAO层数据库连接相同,实现事务的回滚与提交
|
传递Connection出现的问题:

  • 如果使用传递Connection,容易造成接口污染(不同的数据库厂商和框架的数据库连接不同,不一定是Connection)。
  • 定义接口是为了更容易更换实现,从而实现面向接口编程,而将Connection定义在接口中,会造成污染当前接口。

2.解决方案2:ThreadLocal

  • 可以将整个线程中(单线程)中,存储一个共享值。
  • 线程拥有一个类似Map的属性,键值对结构<ThreadLocal对象,值>。
  • 一个线程共享同一个ThreadLocal,在整个流程中任一环节可以存值或取值。
  • 当在线程中存储connection连接时,Service与DAO用的connection连接相同,所以在DAO层用完connection后不要关闭,最后在Service层关闭connection

完善!!!:
为保证程序各层各司其职,Service层不应该出现connection连接对象,更不应该释放资源,所以将代码封装在DBUtils中!!!!

5.示例代码:

import java.io.IOException;
import java.io.InputStream;
import java.sql.*;
import java.util.Properties;public class DBUtils {private static final Properties PROPERTIES=new Properties();    //存储配置文件的map//Driver只加载一次,避免调用getConnection()方法时,检查Driver类是否已加载到程序中!static {InputStream is= DBUtils.class.getResourceAsStream("/db.properties");//通过复用文本自带流,读取配置文件try {PROPERTIES.load(is);    //通过properties对象,将流中配置信息分成键值对String driverName=PROPERTIES.getProperty("driver"); //通过键获取值Class.forName(driverName);  //加载驱动类} catch (IOException e) {e.printStackTrace();} catch (ClassNotFoundException e) {e.printStackTrace();}}//创建一个线程,达到一个程序共享连接private static ThreadLocal<Connection> threadLocal=new ThreadLocal<>();//1.获取连接public static Connection getConnection(){//将当前线程中绑定的connection对象,赋值给connectionConnection connection=threadLocal.get();try {if(connection==null){String url=PROPERTIES.getProperty("url");String username=PROPERTIES.getProperty("username");String password=PROPERTIES.getProperty("password");connection= DriverManager.getConnection(url,username,password);//把连接存在当前共享的线程中threadLocal.set(connection);}} catch (SQLException e) {e.printStackTrace();}return connection;}//开启事务public  static void begin(){Connection connection=getConnection();try {connection.setAutoCommit(false);} catch (SQLException e) {e.printStackTrace();}}//提交事务public static void commit(){//所有连接都是通过ThreadLocal获得,连接是同一个连接Connection connection=null; //  防止在此处出现异常try {connection=getConnection();connection.commit();} catch (SQLException e) {e.printStackTrace();}finally {//提交事务后应该释放资源closeAll(connection,null,null);}}//回滚事务、public static void rollback(){Connection connection=null;try {connection=getConnection();connection.rollback();} catch (SQLException e) {e.printStackTrace();}finally {closeAll(connection,null,null);}}//2.释放资源public static void closeAll(Connection connection, Statement statement, ResultSet resultSet){try {if(resultSet!=null){resultSet.close();}if(statement!=null){statement.close();}if(connection!=null){connection.close();threadLocal.remove();   //  关闭连接后,移除已关闭的connection对象!!!}} catch (SQLException e) {e.printStackTrace();}}
}

http://chatgpt.dhexx.cn/article/8dcM0aef.shtml

相关文章

SpringBoot项目中的controller层、dao层、server层的区别以及对应的功能

&#xff08;1&#xff09;各层简介 Dao层&#xff08;mapper层&#xff09; service层&#xff08;业务层&#xff09; controller层&#xff08;控制层&#xff09; Dao层 即数据持久层&#xff0c;对数据做持久化操作。也被称为mapper层。声明为接口。 dao层的作用为访问数据…

service层的作用是什么?是否可以省略

一个基本的java项目分成Controller层,service层,mapper层等,controller是控制器层,mapper是数据访问层,与数据库相关,进行对数据库的增删改查等操作,service层负责整合mapper层供外部调用,但因为先阶段所涉及的业务量较小,小小的业务涉及这么多层总觉得有些麻烦,于是…

DAO层和Service层的究极理解--这波我在大气层

注重版权&#xff0c;转载请注明原作者和原文链接 作者&#xff1a;码农BookSea 原文链接&#xff1a;https://blog.csdn.net/bookssea/article/details/107488749 先看后赞&#xff0c;养成习惯。 点赞收藏&#xff0c;人生辉煌。 说实话&#xff0c;学了挺久的MVC架构了&…

将网页保存为图片--修改

这里以Chrome浏览器为例 &#xff08;谷歌浏览器&#xff09; 打开需要保存为图片的网页 然后按F12&#xff0c;接着按CtrlShiftP 在红框内输入full 点击下面的“Capture full size screenshot”就可以保存整个网页为图片了 ** 发现不能全部保存网页** 解决方法如下 1.打…

网页保存为PDF遇到的问题(网页打印)

在浏览CSDN上某些干货满满的文章时&#xff0c;我们经常会想将其下载至本地然后反复学习&#xff0c;这时便可以通过浏览器自带的打印功能进行网页保存&#xff0c;但是往往在保存时得不到想要的效果。 问题描述&#xff1a; 本来想以PDF格式将自己的博文保存至本地&#xff…

使用谷歌Chrome浏览器将网页保存为html格式

现版本谷歌Chrome浏览器再也没有"Sava Page as MHTML"一说&#xff0c;将网页保存为MHT、MHTML、HTML格式有俩种途径&#xff1a; 1、下载Save As MHT插件&#xff0c;压缩完成之后在文件中找到后缀名.crx用谷歌浏览打开&#xff0c;然后逐个添加MHT、MHTML 2、鼠标…

牛逼!40行Python代码一键把html网页保存为pdf,太方便了!

公众号 “菜鸟学Python”, 设为 “星标” 第451篇原创&#xff0c;和30w一起学Python&#xff01; 最近临近开学了&#xff0c;大家都在忙着准备各种学习的资料&#xff0c;准备在新的学期好好学习&#xff0c;充实自己。小编身边的同学也是如此&#xff0c;最近&#xff0c;小…

怎么把网页保存成pdf格式-最简单操作

网页怎么保存成pdf格式&#xff0c;会有很多人下载插件&#xff0c;其实不需要那么复杂。只需要简单的两步就可以了。 第一步&#xff1a;打开网页后&#xff0c;鼠标点击右键按打印 第二步&#xff1a;在目标打印机框中更改成另存为pdf模式&#xff0c;点击保存就可以了&…

网页保存为pdf神器(可自定义编辑)—Print Edit WE

1 如何保存一个网页为pdf文件 对于一个网页&#xff0c;如果想保存为一个pdf或者打印&#xff0c;可以直接使用CTRLP即可。但是这样对应的问题就是&#xff0c;网页时全部内容都会被保存进来&#xff0c;包括一些无关的广告或者评论图片等等。例如&#xff1a; 这样就不可避免…

如何查看网页保存的密码

查看网页保存密码 第一种方式,是在浏览器设置查看登陆网页保存的密码,但是不同浏览器操作不同,再次介绍一种通用使用所有网站小白也能操作的方式:修改代码 第一种: 第二种: 再次以简书为例,所有保存密码的都可以适用 首先,要点击填写的账号,会自动弹出提示你点击填充账号密…

Chrome 谷歌浏览器将整个网页保存为图片

两步解决Chrome谷歌浏览器如何将整个网页保存为图片&#xff0c;再也不用慢慢截取一张张图片拼接啦~ 先在需要保存为图片的页面按 F12 打开开发者工具再按 ctrlshiftp 输入full 搜索选择Capture full size screenshot

如何将网页保存成mhtml格式

如何将网页保存成mhtml格式 网页归档&#xff08;英语&#xff1a;MIME HTML或MIME Encapsulation of Aggregate HTML Documents&#xff0c;又称单一档案网页或网页封 存档案&#xff09;为以多用途互联网邮件扩展格式&#xff0c;将一个多附件网页&#xff08;如包含大量图片…

[Chrome] 超级好用的网页保存插件

需求背景&#xff1a; 1、有时候断网&#xff0c;不能浏览自己收藏的文章&#xff1b; 2、有时候网站服务器维护&#xff0c;自己写的文章竟然也不能浏览&#xff1b; 3、有时候明明收藏了别人的文章&#xff0c;还重点标记了&#xff0c;过几天&#xff0c;结果找不到了&#…

edge保存网页html,微软Edge浏览器不支持网页保存功能怎么办?

微软 Edge 浏览器自发布以来一直在不断完善与改进中&#xff0c;在添加了扩展插件功能后&#xff0c;Edge 浏览器的功能性得到了显著改进&#xff0c;但对于某些用户来说&#xff0c;Edge 仍旧欠缺一项非常重要的特性——将网页保存至本地设备的功能。 “保存网页到本地”是一项…

保存html为pdf,将网页保存为PDF的几种方法

方法一 虚拟打印机打印(1) 优点&#xff1a;字体正常、公式正常、文字可选 不足&#xff1a;链接失效优点&#xff1a;字体正常、公式正常、文字可选 工具&#xff1a;IE 浏览器 Foxit Reader PDF Printer 步骤&#xff1a; 1.在网页空白处单击右键&#xff0c;选择“打印”。…

浏览器网页保存长图

在需要保存的网页页面&#xff0c;按F12&#xff0c;弹出开发者工具&#xff0c;再按ctrlshiftp&#xff0c;在弹出框输入“full”&#xff0c;选择弹出的“capture full size screenshot”&#xff0c;就可以保存需要的网页长图了

如何将网页保存为pdf

有的时候我们需要备份某一个网页&#xff0c;但是直接收藏有的时候源链接会被删除&#xff0c;如果保存成网页&#xff0c;文件又很多&#xff0c;保存成PDF格式是一个不错的选择&#xff0c;下面就跟大家分享一个简单的方法。 首先&#xff0c;点击浏览器右上角的…三个点 我…

python将网页保存为pdf,python-网页保存为pdf

今天用到是python的一个第三方库: pdfkit pdfkit 是一个十分强大的第三方库,只需要把网页的url(需要登录或其他特殊方式才能访问的除外)传入,仅靠它自己就能将网页保存为pdf。当然,pdfkit 库也支持文件和源码的传入,同样能将获取到的保存为pdf。 使用工具:pdfkit 环境准备…

如何找到jsp生成的java文件

按照上图所示Using CATALINA_BASE的路径寻找即可。