亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java操作數(shù)據(jù)庫(行級鎖,for update)

 更新時間:2021年12月15日 11:23:37   作者:韶光不負(fù)  
這篇文章主要介紹了Java操作數(shù)據(jù)庫(行級鎖,for update),文章圍繞Java操作數(shù)據(jù)庫的相關(guān)資料展開詳細(xì)內(nèi)容,需要的小伙伴可以參考一下,希望對你有所幫助

一、悲觀鎖(也叫行級鎖)

在本次事務(wù)的執(zhí)行過程當(dāng)中,我們指定的記錄被查詢,在我查詢的過程當(dāng)中記錄就會被鎖定,任何人,任何事務(wù)都不能對我指定查詢數(shù)據(jù)進行修改操作(不能改,但是可以看),直到我都查詢結(jié)束。

1.使用悲觀鎖(在事務(wù)中的sql語句中使用)

//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ū)動
 
            //獲取數(shù)據(jù)庫對象
             conn = JdbcUtil.getConnection();
 
            //sql指令
            String sql = "select * from  t_shuihuo where id < ? for update ";
 
            conn.setAutoCommit(false);//開啟事務(wù)
 
            //3,sql語句進行編譯
            stat = conn.prepareStatement(sql);
 
            //給占位符填充值
            //JDBC下標(biāo)從1開始的
            stat.setInt(1,16); //1,代表第一個問號
 
            Thread.sleep(1000*10); //模擬訪問時間
 
            //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..測試代碼

package com.luosf.jdbc;
 
import com.luosf.jdbc.utils.JdbcUtil;
 
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
 
/**
 * 檢測鎖
 */
public class JdbcLockTest {
    public static void main(String[] args) {
        Connection conn = null;
        PreparedStatement stat = null;
 
        try {
            //獲取驅(qū)動
 
            //獲取數(shù)據(jù)庫鏈接對象
            conn = JdbcUtil.getConnection();
 
            //開啟事務(wù)
            conn.setAutoCommit(false);
 
            //鎖開始后進行修改數(shù)據(jù)
            String sql = "update t_shuihuo set name = '小羅' where id  = ?  ";
            stat = conn.prepareStatement(sql);
 
            stat.setInt(1,10); //1,代表第一個問號
 
            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);
        }
    }
}


需要等鎖等待時間完成才能進行修改

4.結(jié)論

在MySQL當(dāng)中:

在執(zhí)行“select ... from ....whrer ...for update ”對,MySQL進行row lock(行鎖) 還是 table lock(表鎖),取決于是否使用索引(如主鍵,unique字段),則為row lock(行鎖),否則為 table lock(表鎖),沒有查找到數(shù)據(jù)為無鎖,當(dāng)使用“<>” 或者“l(fā)ike”時,索引會失效,進行 table lock(表鎖)。

簡單點來說就是for update最好鎖 主鍵或者unique字段,鎖其他字段會導(dǎo)致整張表被鎖。導(dǎo)致性能的降低

到此這篇關(guān)于Java操作數(shù)據(jù)庫(行級鎖,for update)的文章就介紹到這了,更多相關(guān)Java操作數(shù)據(jù)庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺析java中String類型中“==”與“equal”的區(qū)別

    淺析java中String類型中“==”與“equal”的區(qū)別

    這篇文章主要介紹了淺析java中String類型中“==”與“equal”的區(qū)別,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-08
  • Spring Boot 配置和使用多線程池的實現(xiàn)

    Spring Boot 配置和使用多線程池的實現(xiàn)

    這篇文章主要介紹了Spring Boot 配置和使用多線程池的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • 詳解批處理框架之Spring Batch

    詳解批處理框架之Spring Batch

    Spring Batch是一個輕量級的、完善的批處理框架,作為Spring體系中的一員,它擁有靈活、方便、生產(chǎn)可用的特點。在應(yīng)對高效處理大量信息、定時處理大量數(shù)據(jù)等場景十分簡便。結(jié)合調(diào)度框架能更大地發(fā)揮Spring Batch的作用
    2021-06-06
  • SpringBoot+RabbitMQ方式收發(fā)消息的實現(xiàn)示例

    SpringBoot+RabbitMQ方式收發(fā)消息的實現(xiàn)示例

    這篇文章主要介紹了SpringBoot+RabbitMQ方式收發(fā)消息的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • IDEA 2020版本最新破解教程可激活至2089年(推薦)

    IDEA 2020版本最新破解教程可激活至2089年(推薦)

    這篇文章主要介紹了IDEA 2020版本最新破解教程可激活至2089年,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • 淺析 Java多線程

    淺析 Java多線程

    這篇文章主要介紹了Java多線程的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)Java線程相關(guān)知識,感興趣的朋友可以了解下
    2020-09-09
  • Java 實現(xiàn)瀏覽器下載文件及文件預(yù)覽

    Java 實現(xiàn)瀏覽器下載文件及文件預(yù)覽

    這篇文章主要介紹了Java 實現(xiàn)瀏覽器下載文件及文件預(yù)覽,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • 解決Spring Cloud Gateway獲取body內(nèi)容,不影響GET請求的操作

    解決Spring Cloud Gateway獲取body內(nèi)容,不影響GET請求的操作

    這篇文章主要介紹了解決Spring Cloud Gateway獲取body內(nèi)容,不影響GET請求的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • springboot整合security和vue的實踐

    springboot整合security和vue的實踐

    本文主要介紹了springboot整合security和vue的實踐,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • java排查死鎖示例

    java排查死鎖示例

    這篇文章主要介紹了java排查死鎖示例,通過java中簡單的死鎖示例引出四種排查死鎖的工具,詳細(xì)講解請看全文,希望對大家有所幫助
    2021-08-08

最新評論