跳过正文

MySQL

MySQL的可重复读怎么这么坑
·5 分钟
后端 数据库 MySQL
一、线上问题:更新一个不存在的值,竟锁住“未来数据”? # 最近朋友遇到一个匪夷所思的线上故障:一条看似普通的 SQL UPDATE user SET status=1 WHERE biz_id=999(假设表中当前最大 biz_id=300),竟然导致后续所有 biz_id > 300 的插入请求全部阻塞!更夸张的是,这个操作甚至锁住了 biz_id=300(存在的记录)的插入请求。​明明更新的值不存在,为何会触发“锁扩散”?​​
MySQL Group By 还可以用来去重
·5 分钟
后端 数据库 MySQL
最近在接手老项目的时候,看到一个SQL: select * from xx group by id, 当时一看到这句就感觉,这个group by是不是多余的,既然select 全部了,那去掉其实也无所谓, 然后询问上一个接手的同事才知道这个是用来去重了,好家伙,以前一直用来分组统计的语句竟然可以用来 去重,涨知识了