mysql学习笔记三

1.在 InnoDB 事务中,行锁是在需要的时候才加上的,但并不是不需要了就立刻释放,而是要等到事务结束时才释放。所以把
最可能造成锁冲突、最可能影响并发度的锁尽量往后放

2.设置innodb_deadlock_detect=on来开启死锁自动检测,如果在热点更新的情况下,建议引入中间件来削峰。

3.一般情况下,尽量选用普通索引,唯一索引引入更多的开销。

4.给字符串字段加索引,可以定义一部分作为前缀索引,比如:alter table SUser add index index2(email(6)); 减少索引的长度,可以节省空间,但是有可能会增加扫描次数。一般可以使用如下的语句来区分前缀索引适合的长度:
 

select
 count(distinct left(email,4))as L4,
 count(distinct left(email,5))as L5,
 count(distinct left(email,6))as L6,
 count(distinct left(email,7))as L7,
from SUser;

同时,前缀索引会使覆盖索引失效,即使前缀是完整的长度

5.如果索引字段字符太长,还可以使用hash字段来减少长度。比如使用crc32()来计算出一个新的字段,但是hash可能会碰撞,所以查询时还得带上原来的值来进一步判断。

6.设置 innodb_file_per_table=on,使每个innodb表数据存储在一个.ibd为后缀的文件中。使用delete命令,只是吧不需要数据标记成可复用,但是磁盘文件大小不会改变。不止删除,插入也会造成这种空洞现象。解决方法是重建表: alter table A engine=InnoDB。

7.统计总数,建议用count(*),innodb对这条语句做了相应的优化。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值