Java操作數(shù)據(jù)庫(kù)(行級(jí)鎖,for update)
一、悲觀鎖(也叫行級(jí)鎖)
在本次事務(wù)的執(zhí)行過(guò)程當(dāng)中,我們指定的記錄被查詢(xún),在我查詢(xún)的過(guò)程當(dāng)中記錄就會(huì)被鎖定,任何人,任何事務(wù)都不能對(duì)我指定查詢(xún)數(shù)據(jù)進(jìn)行修改操作(不能改,但是可以看),直到我都查詢(xú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,處理查詢(xún)結(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 + " 昵稱(chēng) :"+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)文章
spring boot 自定義starter的實(shí)現(xiàn)教程
下面小編就為大家分享一篇spring boot 自定義starter的實(shí)現(xiàn)教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-12-12
mybatis使用foreach標(biāo)簽進(jìn)行嵌套插入
數(shù)據(jù)庫(kù)插入操作常見(jiàn)于多層架構(gòu)設(shè)計(jì)中,本文提供了一個(gè)具體的實(shí)現(xiàn)方案,涉及三層實(shí)體類(lèi)結(jié)構(gòu),第一層實(shí)體類(lèi)負(fù)責(zé)基本數(shù)據(jù)結(jié)構(gòu)的定義,第二層和第三層實(shí)體類(lèi)則提供更詳細(xì)的業(yè)務(wù)邏輯處理,同時(shí),文章還介紹了相應(yīng)的mapper接口和配置文件設(shè)置2024-09-09
初步解析Java中AffineTransform類(lèi)的使用
這篇文章主要介紹了Java中AffineTransform類(lèi)的使用,AffineTransform類(lèi)經(jīng)常被用來(lái)處理圖片,需要的朋友可以參考下2015-10-10
Mybatis?Plus?新版lambda?表達(dá)式查詢(xún)異常的處理
這篇文章主要介紹了Mybatis?Plus?新版lambda?表達(dá)式查詢(xún)異常的處理方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01
Servlet+JDBC實(shí)現(xiàn)登陸功能的小例子(帶驗(yàn)證碼)
這篇文章主要介紹了Servlet+JDBC實(shí)現(xiàn)登陸功能的小例子(帶驗(yàn)證碼),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06

