那些年踩过的mysql的坑

时间:2020-12-23 14:55:02

这篇文章都是平时使用的时候踩到的坑,以后估计坑越来越多,有时间会继续补坑
当然有些问题可能不仅仅是mysql的问题,有些具有普适性~~

1. 锁机制带来的锁死

  1. 如果不是通过主键来删除,而是通过其他的字段来删除,那么会导致表级锁,其他insert无法操作。
  2. 同理,不通过主键update 的时候,也会有锁表的情况,同样导致的相同的情况。

2. 在大表中进行删除

千万别试图删除一张没有索引的大表,时间会超出你的想像。先采用逻辑删除,以后再找个空闲时间在后台慢慢删除。

3. 过分依赖视图而不是表:

过分依赖视图会造成性能瓶颈,特别生成视图底层表的关联比较多的情况。依赖视图不容易优化。

4. 在主库中进行查询

如果需要频繁的查询,但是主库中又存在频繁的update或者insert,那么这样查询也是很慢的。这时可以使用salve数据库,只进行读的操作。如果查询的数据分时间的话,可以按时间进行分表。在每个表中进行查找也会加快速度。

5. 关了connection也会出事情

一般我们在创建连接后,一般都会调用 connection.close() 将连接关掉。如果高频率的创建连接然后关闭,过一段时间后,你会发现端口被用完了,无法创建连接了。明明连接已经关掉了啊。 其实即使你已经close了,mysql服务器仍然会把你连接的信息保存2个小时(默认值),端口暂时也不会给其他进程用。如果你频繁的创建连接,很快就吃完所有的端口。
解决办法也很简单,上连接池吧,推荐两个包:DBUtils和SqlAlchemy