![](https://img-blog.csdnimg.cn/20201014180756925.png?x-oss-process=image/resize,m_fixed,h_64,w_64)
数据库
chen591007
这个作者很懒,什么都没留下…
展开
-
建立索引的原则总结
数据库建立索引的原则 1,确定针对该表的操作是大量的查询操作还是大量的增删改操作。 2,尝试建立索引来帮助特定的查询。检查自己的sql语句,为那些频繁在where子句中出现的字段建立索引。 3,尝试建立复合索引来进一步提高系统性能。修改复合索引将消耗更长时间,同时,复合索引也占磁盘空间。 4,对于小型的表,建立索引可能会影响性能 5,应该避免对具有较少值的字段进行索引。 6,避免选择大型数据类型的列作为索引。 7,在SQL语句中经常进行GROUP BY、ORDER BY的字段上建立索引; ...原创 2021-02-13 21:13:59 · 190 阅读 · 0 评论 -
Mysql行锁和表锁
1.表级别的锁定是MySQL各存储引擎中最大颗粒度的锁定机制。该锁定机制最大的特点是实现逻辑非常简单,带来的系统负面影响最小。所以获取锁和释放锁的速度很快。由于表级锁一次会将整个表锁定,所以可以很好的避免困扰我们的死锁问题。锁定颗粒度大所带来最大的负面影响就是出现锁定资源争用的概率也会最高,致使并大度大打折扣。 2.行级锁定最大的特点就是锁定对象的颗粒度很小,也是目前各大数据库管理软件所实现的锁定颗粒度最小的。由于锁定颗粒度很小,所以发生锁定资源争用的概率也最小,能够给予应用程序尽可能大的并发处理能力而提高转载 2021-02-08 13:47:35 · 320 阅读 · 0 评论 -
mysql行锁和行锁检测
行锁顾名思义,就是针对单行数据加锁,在mysql中,锁的实现是由引擎层实现的,MyISAM引擎就不支持行锁不支持行锁就意味着并发控制只能使用表锁,也就是说同一时间,在这个表上只能有一个更新在执行,这就会影响到业务的并发度。InnoDB是支持行锁的,这也是MyISAM被InnoDB替代的重要原因之一。 事务B在执行这条语句时会被阻塞 其实事务A的加锁时机是执行第一条语句的时候,释放锁的时候是commit完以后 但是事务B是在事务A commit前执行的 这个时候事务A还持有id=1这行数据的锁,所以事务B会被转载 2021-02-04 17:03:06 · 310 阅读 · 0 评论 -
mysql中的for update
for update是在数据库中上锁用的,可以为数据库中的行上一个排它锁。当一个事务的操作未完成时候,其他事务可以读取但是不能写入或更新。 如果遇到存在高并发并且对于数据的准确性很有要求的场景,是需要了解和使用for update的。 比如涉及到金钱、库存等。一般这些操作都是很长一串并且是开启事务的。如果库存刚开始读的时候是1,而立马另一个进程进行了update将库存更新为0了,而事务还没有结束,会将错的数据一直执行下去,就会有问题。所以需要for upate 进行数据加锁防止高并发时候数据出错。 记住一个转载 2021-02-03 21:25:30 · 188 阅读 · 0 评论 -
数据库的脏读幻读不可重复读和隔离级别等
1.脏读(读取未被提交的数据) A事务读取B事务尚未提交的数据,此时如果B事务发生了错误执行了回滚操作,那么A事务读取道德数据就是脏数据。就好比原本比较干净纯粹的数据,由于B事务更改了它,它变得不再纯粹,这个时候A事务读取了这个数据,但是事务B良心发现,把数据恢复成了原来干净的样子,可是事务A却并不知道。 2.幻读(前后多次读取,数据总量不一致) 事务A在执行读取操作,要统计量词数据量,前一次查询总量之后,此时事务B执行新增数据操作并且提交之后,这时候事务A读取的数据总量和之前统计的不一样,就像产生幻觉一样原创 2021-01-31 14:26:40 · 69 阅读 · 0 评论