Java操作数据库(行级锁,for update)
一、悲观锁(也叫行级锁)
在本次事务的执行过程当中,我们指定的记录被查询,在我查询的过程当中记录就会被锁定,任何人,任何事务都不能对我指定查询数据进行修改操作(不能改,但是可以看),直到我都查询结束。
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; /** * JDBC中锁的使用 * for updata */ 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操作数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
SpringBoot 下在 yml 中的 logging 日志配置方法
logging 配置主要用于控制应用程序的日志输出行为,可以通过配置定制日志的格式、级别、输出位置等,这篇文章主要介绍了SpringBoot 下在 yml 中的 logging 日志配置,需要的朋友可以参考下2024-06-06spring注解如何为bean指定InitMethod和DestroyMethod
这篇文章主要介绍了spring注解如何为bean指定InitMethod和DestroyMethod,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-11-11SpringMVC源码解析之消息转换器HttpMessageConverter
本篇文章主要介绍了SpringMVC源码解析之消息转换器HttpMessageConverter ,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2017-11-11jenkins如何通过pipeline部署springboot项目
为了提高SpringBoot项目的部署效率和规范性,建议将项目代码和部署脚本分离,项目代码仓库专注业务逻辑,构建为jar包;另外设立独立代码仓库存放Jenkinsfile等部署配置文件,在Jenkins中配置pipeline,自动拉取项目代码进行构建和部署2024-09-09Spring context:component-scan的使用及说明
这篇文章主要介绍了Spring context:component-scan的使用及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2023-09-09
最新评论