Spring JDBC和事務管理

Spring JDBC是Spring框架用來處理關系型數據庫的模塊,對JDBC的API進行了封裝。

Spring JDBC的核心類為JdbcTemplate,提供數據CRUD方法

Spring JDBC使用步驟

  1. Maven工程引入依賴spring-jdbc
<dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId><version>5.2.6.RELEASE</version>
</dependency>
<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.27</version>
</dependency>
  1. xml中配置DataSource數據源
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"><property name="driverClassName" value="com.mysql.cj.jdbc.Driver"></property><property name="url" value="jdbc:mysql://localhost:3306/test"></property><property name="username" value="root"></property><property name="password" value="root"></property>
</bean>
  1. xml中定義JdbcTemplate Bean,讓IoC容器初始化時自動實例化
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"><property name="dataSource" ref="dataSource"></property>
</bean>
  1. 在需要增刪改查的Dao中,持有JdbcTemplate屬性,并設置getter和setter方法,然后在對應的業務處理方法中,調用JdbcTemplate的指定方法。
public class EmployeeDao {private JdbcTemplate jdbcTemplate;//數據查詢方法public Employee findById(Integer eno){String sql="select * from employee where eno = ?";Employee employee = jdbcTemplate.queryForObject(sql,new Object[]{eno},new BeanPropertyRowMapper<>(Employee.class));return employee;}public JdbcTemplate getJdbcTemplate() {return jdbcTemplate;}public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {this.jdbcTemplate = jdbcTemplate;}
}
  1. 在xml中為Dao類注入JdbcTemplate對象
<bean id="employeeDao" class="spring.jdbc.dao.EmployeeDao"><property name="jdbcTemplate" ref="jdbcTemplate"></property>
</bean>

JdbcTemplate數據查詢方法:

在這里插入圖片描述
例:

public List<Employee> findByDname(String dname){String sql = "select * from employee where dname = ?";List<Employee> list = jdbcTemplate.query(sql,new Object[]{dname},new BeanPropertyRowMapper<>(Employee.class));return list;
}
public List<Map<String, Object>> findMapByDname(String dname){String sql = "select eno as  empno,salary as s from employee where dname = ?";List<Map<String, Object>> maps = jdbcTemplate.queryForList(sql, new Object[]{dname});return maps;
}

JdbcTemplate數據寫入方法:
在這里插入圖片描述

例:

	public void insert(Employee employee){String sql = "insert into employee(eno,ename,salary,dname) values(?,?,?,?)";//利用update方法實現數據寫入操作jdbcTemplate.update(sql,new Object[]{employee.getEno(),employee.getEname(),employee.getSalary(), employee.getDname()});}public int update(Employee employee){String sql = "update employee set ename=?,salary=?,dname=? where eno=?";//利用update方法實現數據更新操作int count = jdbcTemplate.update(sql,new Object[]{employee.getEname(),employee.getSalary(), employee.getDname(),employee.getEno()});return count;}public int delete(Integer eno){String sql = "delete from employee where eno = ?";//利用update方法實現數據刪除操作return jdbcTemplate.update(sql,new Object[]{eno});}

Spring事務管理

事務是一種可靠、一致的方式,是訪問操作數據庫的程序單元,事務要么把事情做完,要么不做,不會做一半停止。
事務依賴數據庫實現,MySQL通過事務區作為數據緩沖地帶。

編程式事務

通過代碼手動提交回滾事務的事務控制方式。

SpringJDBC通過TransactionManager事務管理器實現事務控制。

TransactionManager事務管理器提供commit、rollback方法進行事務提交和回滾。

編程式事務使用步驟:

  1. 配置事務管理器
<!--    事務管理器--><bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><property name="dataSource" ref="dataSource"></property></bean>
  1. 在需要開啟事務的業務類中,持有事務管理器屬性,并設置getter和setter方法
	private DataSourceTransactionManager transactionManager;public DataSourceTransactionManager getTransactionManager() {return transactionManager;}public void setTransactionManager(DataSourceTransactionManager transactionManager) {this.transactionManager = transactionManager;}
  1. 配置事務管理器對象注入
<bean id="employeeService" class="spring.jdbc.service.EmployeeService"><property name="employeeDao" ref="employeeDao"></property><property name="transactionManager" ref="transactionManager"></property>
</bean>
  1. 定義事務默認的標準配置,開啟事務,進行事務管理
    在這里插入圖片描述

聲明式事務

在不修改代碼的情況下通過配置的形式實現事務控制,本質就是AOP環繞通知。

聲明式事務的觸發時機:

  • 當目標方法執行成功時,自動提交事務
  • 當目標方法拋出運行時異常時,自動事務回滾

聲明式事務配置過程:

  1. 需要添加AOP依賴
<dependency><groupId>org.aspectj</groupId><artifactId>aspectjweaver</artifactId><version>1.9.5</version>
</dependency>
  1. 添加tx和aop命名空間

在這里插入圖片描述

  1. 配置TransactionManager事務管理器
<!--    事務管理器--><bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><property name="dataSource" ref="dataSource"></property></bean>
  1. 配置事務通知與事務屬性
	<!--事務通知配置,決定哪些方法使用事務,哪些方法不使用事務--><tx:advice id="txAdvice" transaction-manager="transactionManager"><tx:attributes><!--propagation事務傳播行為--><!--當目標方法名為batchImport時,啟用聲明式事務,運行成功提交事務,運行時異常回滾--><!--目標方法允許使用通配符*--><tx:method name="batchImport" propagation="REQUIRED"/><!--設置所有findXXX方法不啟用事務--><tx:method name="find*" propagation="NOT_SUPPORTED" read-only="true"/><tx:method name="get*" propagation="NOT_SUPPORTED" read-only="true"/><!--設置其他方法不啟用事務--><tx:method name="*" propagation="NOT_SUPPORTED" read-only="true"/></tx:attributes></tx:advice>
  1. 為事務通知綁定PointCut切點
<!--定義聲明式事務的作用范圍--><aop:config><aop:pointcut id="pointcut" expression="execution(* spring.jdbc..*Service.*(..))"/><aop:advisor advice-ref="txAdvice" pointcut-ref="pointcut"/></aop:config>
事務傳播行為propagation

多個擁有事務的方法在嵌套調用時的事務控制方式。

在這里插入圖片描述

注解配置聲明式事務
  1. xml配置
	<context:component-scan base-package="spring.jdbc"/><!--數據源--><bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"><property name="driverClassName" value="com.mysql.cj.jdbc.Driver"></property><property name="url" value="jdbc:mysql://localhost:3306/test"></property><property name="username" value="root"></property><property name="password" value="root"></property></bean><bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"><property name="dataSource" ref="dataSource"></property></bean><!--事務管理器--><bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><property name="dataSource" ref="dataSource"></property></bean><!--啟用注解形式聲明式事務--><tx:annotation-driven transaction-manager="transactionManager"/>
  1. 分層添加組件注解,實例化對象
@Repository
public class EmployeeDao {@Resourceprivate JdbcTemplate jdbcTemplate;...
@Service
public class EmployeeService {@Resourceprivate EmployeeDao employeeDao;...
  1. 需要開啟事務的類添加@Transactional注解,可以設置事務傳播行為,如@Transactional(propagation = Propagation.REQUIRED

在這里插入圖片描述

或者為方法單獨設置事務管理方式,程序執行時優先應用方法上的配置

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/213132.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/213132.shtml
英文地址,請注明出處:http://en.pswp.cn/news/213132.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

springboot 整合nacos

Spring Boot整合Nacos 大家好&#xff0c;我是微賺淘客系統3.0的小編&#xff0c;也是冬天不穿秋褲&#xff0c;天冷也要風度的程序猿&#xff01;今天&#xff0c;我將帶領大家探索一個讓微服務架構更加便捷的利器——Spring Boot整合Nacos。在當今快速發展的互聯網時代&#…

應用安全:JAVA反序列化漏洞之殤

應用安全:JAVA反序列化漏洞之殤 概述 序列化是讓Java對象脫離Java運行環境的一種手段&#xff0c;可以有效的實現多平臺之間的通信、對象持久化存儲。Java 序列化是指把 Java 對象轉換為字節序列的過程便于保存在內存、文件、數據庫中&#xff0c;ObjectOutputStream類的 wri…

MYSQL創建用戶以及解決MYSQL新建數據庫看不到相關數據庫信息的解決方案

MYSQL創建用戶以及解決MYSQL新建數據庫看不到相關數據庫信息的解決方案 首先 我們在root用戶下&#xff0c;創建一個mysql用戶賬戶 如創建一個test用戶 密碼123456 命令如下&#xff1a; CREATE USER ‘test’‘localhost’ IDENTIFIED BY ‘123456’; 創建了一個db1的數據庫 …

唯創知音WTN6040F-8S語音芯片在空氣消毒機中的應用:提升用戶體驗與健康保障

在現代生活中&#xff0c;空氣質量成為人們越來越關注的問題。空氣消毒機作為一種能夠凈化空氣、殺滅病毒細菌的設備&#xff0c;受到了廣大消費者的青睞。然而&#xff0c;對于很多用戶來說&#xff0c;操作空氣消毒機可能存在一定的困惑和不便。為了解決這一問題&#xff0c;…

對Spring源碼的學習:Bean實例化流程

目錄 SpringBean實例化流程 Spring的后處理器 Bean工廠后處理器 Bean后處理器 SpringBean實例化流程 Spring容器在進行初始化時&#xff0c;會將xml配置的<bean>的信息封裝成一個BeanDefinition對象&#xff0c;所有的BeanDefinition存儲到一個名為beanDefinitionMa…

Docker容器的可視化管理工具—DockerUI本地部署與遠程訪問

文章目錄 前言1. 安裝部署DockerUI2. 安裝cpolar內網穿透3. 配置DockerUI公網訪問地址4. 公網遠程訪問DockerUI5. 固定DockerUI公網地址 前言 DockerUI是一個docker容器鏡像的可視化圖形化管理工具。DockerUI可以用來輕松構建、管理和維護docker環境。它是完全開源且免費的。基…

【GlobalMapper精品教程】066:shp轉JSON(GeoJson)案例實現

文章目錄 一、JSON與GeoJson的區別二、globalmapper實現shp轉JSON1. 加載shp數據2. shp轉json一、JSON與GeoJson的區別 JSON(JavaScript Object Notation)是一種輕量級的數據交換格式,它基于JavaScript的語法,可以將JavaScript對象中表示的一組數據轉換為字符串,在函數之…

ElasticSearch之cat recovery API

命令樣例如下&#xff1a; curl -X GET "https://localhost:9200/_cat/recovery?vtrue&pretty" --cacert $ES_HOME/config/certs/http_ca.crt -u "elastic:ohCxPHQBEs5*lo7F9"執行結果輸出如下&#xff1a; index shard time type sta…

2023 CCF中國軟件大會(CCF ChinaSoft) “程序語義深度理解前沿進展”論壇成功召開...

2023年12月2日&#xff0c;2023年度CCF中國軟件大會軟件程序語義深度理解前沿進展論壇成功召開。 本次論壇由南京大學卜磊老師和國防科技大學陳振邦老師主持&#xff0c;計算機研究與發展期刊代表侯麗珊老師致辭&#xff0c;旨在反映程序語義理解及其應用相關研究前沿進展與實踐…

Vue之模板語法

模板語法有兩大類&#xff1a; 1.插值語法 2.指令語法 讓我為大家介紹一下吧&#xff01; 一、插值語法 功能:用于解析標簽體內容。 寫法: {{xxx}}&#xff0c;xxx是js表達式&#xff0c;且可以直接讀取到data中的所有屬性。 舉個例子&#xff1a; <!DOCTYPE html> &l…

探索未來新趨勢:鴻蒙系統的嶄新時代

探索未來新趨勢&#xff1a;鴻蒙系統的嶄新時代 隨著科技的不斷發展&#xff0c;操作系統作為計算機和移動設備的核心&#xff0c;扮演著至關重要的角色。近年來&#xff0c;一種備受矚目的操作系統——鴻蒙系統&#xff08;HarmonyOS&#xff09;嶄露頭角&#xff0c;正引領著…

uniapp 微信小程序請求攔截器 接口封裝

前言&#xff1a; 請求攔截器可以在我們需要傳遞請求頭的時候使用&#xff0c;例如&#xff1a;token 也會在當token發生變化的時候給予響應&#xff0c;所以我們做好對應的判斷即可 話不多說&#xff0c;直接進入正題&#xff1a; 1.首先在根目錄創建common文件夾&#xff0c…

Selenium 中并行測試的重要性!

隨著技術的進步&#xff0c;測試解決方案變得更具可擴展性&#xff0c;加速了團隊從手動測試到Selenium測試自動化的轉型。但是成年人的世界&#xff0c;沒有什么是容易的。對于許多團隊來說&#xff0c;并行運行多個測試仍然是不可擴展的。他們傾向于遵循傳統的順序執行測試方…

MIT6.5840-2023-Lab2A: Raft-leader election

前置知識 什么是一致性算法&#xff1f; 安全性保證&#xff0c;絕對不會返回一個錯誤的結果&#xff1b;可用性&#xff0c;容忍集群部分節點失敗&#xff1b;不依賴時序來保證一致性&#xff1b;一條指令可以盡可能快的在集群中大多數節點響應一輪遠程過程調用時完成。小部分…

uniapp實戰 —— 可滾動區域 scroll-view (自適配高度,下拉刷新)

自適配高度 自定義的頂部導航欄&#xff0c;可參考博文 https://blog.csdn.net/weixin_41192489/article/details/134852124 如圖可見&#xff0c;在頁面滾動過程中&#xff0c;頂部導航欄和底欄未動&#xff0c;僅中間的內容區域可滾動。 整個頁面的高度設置為 100%&#xf…

鴻蒙開發—學習聲明式UI

基本UI描述 ArkTS通過裝飾器Component和Entry裝飾struct關鍵字聲明的數據結構&#xff0c;構成一個自定義組件。自定義組件中提供了一個build函數&#xff0c;開發者需在該函數內以鏈式調用的方式進行基本的UI描述&#xff0c;UI描述的方法請參考UI描述規范。 基本概念 stru…

GZ029 智能電子產品設計與開發賽題第4套

2023年全國職業院校技能大賽高職組 “GZ029智能電子產品設計與開發”賽項賽卷四 題目&#xff1a;模擬工業傳送帶物品檢測系統的設計與開發 1 競賽任務 在智能電視機上播放工業傳送帶傳輸物品視頻&#xff0c;模擬工業傳送帶物品檢測系統&#xff08;以下簡稱物品檢測系統&…

DALI1.0學習——BIT解碼

最近在學習DALI調光相關知識并下載了Microchip提供的基于ATMega88PA的軟件工程及硬件設計參考方案。寫這些文章的目的就是把自己對知識的理解作一些梳理。 芯片廠果然專業&#xff0c;考慮得相當周到&#xff0c;為了芯片銷量連軟件和硬件方案全都提供了。芯片廠關于DALI1.0實…

【unity小技巧】實現槍武器隨鏡頭手臂搖擺效果

文章目錄 前言方法一、改變武器位置方法二、改變武器旋轉結語完結 前言 如果我們視角移動轉向&#xff0c;武器如果不跟著進行搖擺&#xff0c;會感覺我們的動作很生硬&#xff0c;特別是射擊類游戲&#xff0c;如下 實現武器搖擺這里主要分享兩種實現方法&#xff0c;一種是…

xtu oj 1271 color

題目描述 Alice在玩一個游戲&#xff0c;她在一個mn的格子里&#xff0c;隨機涂黑k個格子。然后她每次可以把一行或者一列的格子染成紅色&#xff0c;但是這一行中不能有黑色的格子。 請問她最多能把多少個格子涂成紅色&#xff1f; 輸入 第一行是一個整數T(T≤100)&#xf…