2024最新Java面试笔试题目分享,腾讯T4架构师

正文

谈到 MYSQL 的事物, 相信大家对这几个概念都不会陌生:

  • 四大特性:ACID
  • 并发问题
    • 脏读
    • 不可重复读
    • 幻读
  • 隔离级别
    • Read Uncommitted(读未提交)
    • Read Committed(读提交)
    • Repeatable Read(可重读)
    • Serializable(可串行化)

下面的思维导图可能更表达得清晰😏

MySQL 的默认事物隔离级别是 RR (Repeatable Read) ,可重复读级别是能够解决脏读、不可重复读的这两个事物并发问题的,但是幻读的问题仍会存在,如果使用Serializable的隔离级别,对于高并发的业务来说是不实际的。那么 MySQL 是如何解决幻读这个棘手的问题呢?

没错,MySQL 通过MVCC(多版本并发控制)和Gap Lock(间隙锁)这两个机制解决了幻读的问题~

那么这两种方式具体又是如何实现的呢?

这里我们先讲一下 MySQL 的**"

  • 24
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
作为一个Java架构师,我可以建议您使用以下工具来监控慢SQL: 1. 使用JDBC API提供的Statement和PreparedStatement对象的setFetchSize()方法来设置每次从数据库中获取的记录数,以减少网络传输的开销。 2. 使用JDBC API提供的ResultSet对象的setFetchDirection()方法来设置数据的获取方向,以减少网络传输的开销。 3. 使用JDBC API提供的ResultSet对象的setFetchSize()方法来设置每次从数据库中获取的记录数,以减少网络传输的开销。 4. 使用JDBC API提供的ResultSet对象的setFetchDirection()方法来设置数据的获取方向,以减少网络传输的开销。 5. 使用JDBC API提供的Statement和PreparedStatement对象的setMaxRows()方法来限制返回的记录数,以减少网络传输的开销。 6. 使用JDBC API提供的Statement和PreparedStatement对象的setQueryTimeout()方法来设置查询超时时间,以避免查询时间过长。 7. 使用JDBC API提供的Connection对象的setAutoCommit()方法来设置自动提交事务的开关,以避免事务过长。 8. 使用JDBC API提供的Connection对象的setTransactionIsolation()方法来设置事务隔离级别,以避免事务过长。 9. 使用JDBC API提供的Connection对象的setReadOnly()方法来设置只读模式,以避免不必要的写操作。 10. 使用JDBC API提供的PreparedStatement对象的addBatch()方法和executeBatch()方法来批量执行SQL语句,以减少网络传输的开销。 以上是一些常见的优化方法,您可以根据具体情况进行选择和使用。同时,您也可以使用一些第三方的慢SQL监控工具,如阿里巴巴的Druid、腾讯的TDSQL等,这些工具可以帮助您更方便地监控和优化慢SQL。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值