Java操作數(shù)據(jù)庫(kù)(行級(jí)鎖,for update)
一、悲觀鎖(也叫行級(jí)鎖)
在本次事務(wù)的執(zhí)行過(guò)程當(dāng)中,我們指定的記錄被查詢,在我查詢的過(guò)程當(dāng)中記錄就會(huì)被鎖定,任何人,任何事務(wù)都不能對(duì)我指定查詢數(shù)據(jù)進(jìn)行修改操作(不能改,但是可以看),直到我都查詢結(jié)束。
1.使用悲觀鎖(在事務(wù)中的sql語(yǔ)句中使用)
//sql指令 String sql = "select * from t_shuihuo where id < ? for update ";
2..完整代碼
package com.luosf.jdbc; import com.luosf.jdbc.utils.JdbcUtil; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; /** * JDBC中鎖的使用 * for updata */ public class JdbcLock { public static void main(String[] args) { Connection conn = null; PreparedStatement stat = null; ResultSet res = null; try { //創(chuàng)建驅(qū)動(dòng) //獲取數(shù)據(jù)庫(kù)對(duì)象 conn = JdbcUtil.getConnection(); //sql指令 String sql = "select * from t_shuihuo where id < ? for update "; conn.setAutoCommit(false);//開(kāi)啟事務(wù) //3,sql語(yǔ)句進(jìn)行編譯 stat = conn.prepareStatement(sql); //給占位符填充值 //JDBC下標(biāo)從1開(kāi)始的 stat.setInt(1,16); //1,代表第一個(gè)問(wèn)號(hào) Thread.sleep(1000*10); //模擬訪問(wèn)時(shí)間 //4,執(zhí)行sql res = stat.executeQuery(); //5,處理查詢結(jié)果集 while (res.next()){ int id = res.getInt("id"); String name = res.getString("name"); String nickname = res.getString("nickname"); System.out.println("id :"+ id + " name :" +name + " 昵稱 :"+nickname); } conn.commit();//提交事務(wù) } catch (SQLException throwables) { try { if (conn != null){ conn.rollback(); //回滾事務(wù) } } catch (SQLException e) { e.printStackTrace(); } throwables.printStackTrace(); } catch (InterruptedException e) { e.printStackTrace(); } finally{ //釋放資源 JdbcUtil.close(conn,stat,res); } } }
3..測(cè)試代碼
package com.luosf.jdbc; import com.luosf.jdbc.utils.JdbcUtil; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.SQLException; /** * 檢測(cè)鎖 */ public class JdbcLockTest { public static void main(String[] args) { Connection conn = null; PreparedStatement stat = null; try { //獲取驅(qū)動(dòng) //獲取數(shù)據(jù)庫(kù)鏈接對(duì)象 conn = JdbcUtil.getConnection(); //開(kāi)啟事務(wù) conn.setAutoCommit(false); //鎖開(kāi)始后進(jìn)行修改數(shù)據(jù) String sql = "update t_shuihuo set name = '小羅' where id = ? "; stat = conn.prepareStatement(sql); stat.setInt(1,10); //1,代表第一個(gè)問(wèn)號(hào) int cunt = stat.executeUpdate(); System.out.println("更新了"+cunt+"條數(shù)據(jù)"); conn.commit();//提交事務(wù) } catch (SQLException throwables) { try { if (conn != null){ conn.rollback(); } } catch (SQLException e) { e.printStackTrace(); } throwables.printStackTrace(); } finally { //釋放資源 JdbcUtil.close(conn,stat,null); } } }
需要等鎖等待時(shí)間完成才能進(jìn)行修改
4.結(jié)論
在MySQL當(dāng)中:
在執(zhí)行“select ... from ....whrer ...for update
”對(duì),MySQL進(jìn)行row lock
(行鎖) 還是 table lock(表鎖),取決于是否使用索引(如主鍵,unique字段),則為row lock(行鎖),否則為 table lock(表鎖),沒(méi)有查找到數(shù)據(jù)為無(wú)鎖,當(dāng)使用“<>” 或者“l(fā)ike”時(shí),索引會(huì)失效,進(jìn)行 table lock(表鎖)。
簡(jiǎn)單點(diǎn)來(lái)說(shuō)就是for update
最好鎖 主鍵或者unique字段,鎖其他字段會(huì)導(dǎo)致整張表被鎖。導(dǎo)致性能的降低
到此這篇關(guān)于Java操作數(shù)據(jù)庫(kù)(行級(jí)鎖,for update)的文章就介紹到這了,更多相關(guān)Java操作數(shù)據(jù)庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺析java中String類型中“==”與“equal”的區(qū)別
這篇文章主要介紹了淺析java中String類型中“==”與“equal”的區(qū)別,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08Spring Boot 配置和使用多線程池的實(shí)現(xiàn)
這篇文章主要介紹了Spring Boot 配置和使用多線程池的實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06SpringBoot+RabbitMQ方式收發(fā)消息的實(shí)現(xiàn)示例
這篇文章主要介紹了SpringBoot+RabbitMQ方式收發(fā)消息的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09IDEA 2020版本最新破解教程可激活至2089年(推薦)
這篇文章主要介紹了IDEA 2020版本最新破解教程可激活至2089年,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09Java 實(shí)現(xiàn)瀏覽器下載文件及文件預(yù)覽
這篇文章主要介紹了Java 實(shí)現(xiàn)瀏覽器下載文件及文件預(yù)覽,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06解決Spring Cloud Gateway獲取body內(nèi)容,不影響GET請(qǐng)求的操作
這篇文章主要介紹了解決Spring Cloud Gateway獲取body內(nèi)容,不影響GET請(qǐng)求的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12springboot整合security和vue的實(shí)踐
本文主要介紹了springboot整合security和vue的實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09