文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Java操作数据库(行级锁,forupdate)

2024-04-02 19:55

关注

一、悲观锁(也叫行级锁)

在本次事务的执行过程当中,我们指定的记录被查询,在我查询的过程当中记录就会被锁定,任何人,任何事务都不能对我指定查询数据进行修改操作(不能改,但是可以看),直到我都查询结束。

1.使用悲观锁(在事务中的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;
 

public class JdbcLock {
    public static void main(String[] args) {
        Connection conn = null;
        PreparedStatement stat = null;
        ResultSet res = null;
        try {
            //创建驱动
 
            //获取数据库对象
             conn = JdbcUtil.getConnection();
 
            //sql指令
            String sql = "select * from  t_shuihuo where id < ? for update ";
 
            conn.setAutoCommit(false);//开启事务
 
            //3,sql语句进行编译
            stat = conn.prepareStatement(sql);
 
            //给占位符填充值
            //JDBC下标从1开始的
            stat.setInt(1,16); //1,代表第一个问号
 
            Thread.sleep(1000*10); //模拟访问时间
 
            //4,执行sql
            res = stat.executeQuery();
 
            //5,处理查询结果集
            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();//提交事务
        } catch (SQLException throwables) {
            try {
                if (conn != null){
                    conn.rollback(); //回滚事务
                }
 
            } 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 {
            //获取驱动
 
            //获取数据库链接对象
            conn = JdbcUtil.getConnection();
 
            //开启事务
            conn.setAutoCommit(false);
 
            //锁开始后进行修改数据
            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+"条数据");
 
            conn.commit();//提交事务
        } catch (SQLException throwables) {
            try {
                if (conn != null){
                    conn.rollback();
                }
            } catch (SQLException e) {
                e.printStackTrace();
            }
            throwables.printStackTrace();
        } finally {
            //释放资源
           JdbcUtil.close(conn,stat,null);
        }
    }
}


需要等锁等待时间完成才能进行修改

4.结论

在MySQL当中:

在执行“select ... from ....whrer ...for update ”对,MySQL进行row lock(行锁) 还是 table lock(表锁),取决于是否使用索引(如主键,unique字段),则为row lock(行锁),否则为 table lock(表锁),没有查找到数据为无锁,当使用“<>” 或者“like”时,索引会失效,进行 table lock(表锁)。

简单点来说就是for update最好锁 主键或者unique字段,锁其他字段会导致整张表被锁。导致性能的降低

到此这篇关于Java操作数据库(行级锁,for update)的文章就介绍到这了,更多相关Java操作数据库内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯