当前位置:首页 » 存储配置 » mysql的存储优化

mysql的存储优化

发布时间: 2023-06-02 17:52:01

⑴ Mysql内存使用以及优化中需要的几点注意

1、从内存中读取数据是微秒级别的。而从磁盘读则是毫秒级别的。二者相差一个数量级。所以想优化数据库,第一个要做到的就是优化io。
2、key_buffer_size[global]设置的内存区域大小缓存了myisam表的索引。由于myisam只缓存索引在内存中,并不缓存数据在内存,所以如果内存允许,要让这个参数足够能容纳所有myisam的所有索引来提高性能。另外,在myisam表上,尽量让所有的查询条件都限制在索引上,以便能让缓存替我们提高查找效率。
3、bulk_insert_buffer_size[thread]仅仅用在myisam中,用于在插入数据的时候临时缓存数据。当我们使用如下的写入语句的时候,会使用这个内存区域帮助批量写入数据文件:
insert ... select ...
insert into ... values ...

⑵ mysql存储过程的if判断有多个条件该怎么优化效率

这个应该不会太慢吧,我建议你看一下,你是不是循环做了太多次的插入/更新操作。
mysql默认的配置中,每次事务提交都要写binlog和redo log,如果循环太多次——比如循环插入10w条记录——就会非常慢。一般优化思路分两种:
1 修改 sync_binlog为一个100-1000间的值,让binlog每隔100-1000个事务后再写一次;修改innodb_flush_log_at_trx_commit =2; 这么搞的好处是降低了写log的次数和消耗的时间,缺点是,中间出错的话,会丢失一部分的binlog和redolog导致无法通过他们来在出问题是恢复生产库数据。
2 将所有的插入/更新操作放到一个事务中进行。这样,显然就只需要一次写binlong和redolog咯。

⑶ mysql数据库的优化方法

我们都知道,服务器数据库的开发一般都是通过java或者是PHP语言来编程实现的,而为了提高我们数据库的运行速度和效率,数据库优化也成为了我们每日的工作重点,今天,霍营IT培训就一起来了解一下mysql服务器数据库的优化方法。



为什么磨局要了解索引


真实案例


案例一:大学有段时间学习爬虫,爬取了知乎300w用户答题数据,存储到mysql数据中。那时不了解索引,一条简单的“根据用户名搜索全部回答的sql“需要执行半分钟左右,完全满足不了正常的使用。


案例二:近线上应用的数据库频频出现多条慢sql风险提示,而工作以来,对数据库优化方面所知甚少。例如一个用户数据页面需要执行很多次数据库查询,性能很慢,通过增加超时时间勉强可以访问,但是性能上需要优化。


索引的优点


合适的索引,可以大大减小mysql服务器扫描的数据量,避免内存排序和临时表,提高兄稿应用程序的查询性能。


索引的类型


mysql数据中有多种索引类型,primarykey,unique,normal,但瞎尘让底层存储的数据结构都是BTREE;有些存储引擎还提供hash索引,全文索引。


BTREE是常见的优化要面对的索引结构,都是基于BTREE的讨论。


B-TREE


查询数据简单暴力的方式是遍历所有记录;如果数据不重复,就可以通过组织成一颗排序二叉树,通过二分查找算法来查询,大大提高查询性能。而BTREE是一种更强大的排序树,支持多个分支,高度更低,数据的插入、删除、更新更快。


现代数据库的索引文件和文件系统的文件块都被组织成BTREE。


btree的每个节点都包含有key,data和只想子节点指针。


btree有度的概念d>=1。假设btree的度为d,则每个内部节点可以有n=[d+1,2d+1)个key,n+1个子节点指针。树的大高度为h=Logb[(N+1)/2]。


索引和文件系统中,B-TREE的节点常设计成接近一个内存页大小(也是磁盘扇区大小),且树的度非常大。这样磁盘I/O的次数,就等于树的高度h。假设b=100,一百万个节点的树,h将只有3层。即,只有3次磁盘I/O就可以查找完毕,性能非常高。


索引查询


建立索引后,合适的查询语句才能大发挥索引的优势。


另外,由于查询优化器可以解析客户端的sql语句,会调整sql的查询语句的条件顺序去匹配合适的索引。


热点内容
mysql解压缩版安装 发布:2025-02-06 17:26:33 浏览:177
phpgd图片 发布:2025-02-06 17:24:34 浏览:204
php代码整理 发布:2025-02-06 17:24:31 浏览:475
java可执行文件 发布:2025-02-06 17:18:59 浏览:247
卫士相当于现在什么配置 发布:2025-02-06 17:05:04 浏览:409
项目编译慢 发布:2025-02-06 16:53:48 浏览:382
python处理excel文件 发布:2025-02-06 16:36:09 浏览:442
算法相对定位 发布:2025-02-06 16:32:42 浏览:728
java程序的编译和执行 发布:2025-02-06 16:21:45 浏览:420
什么是淘宝帐号和密码 发布:2025-02-06 16:21:36 浏览:498