对mysql存储性能优化的基本理解

WBOY
发布: 2016-06-07 16:19:14
原创
778 人浏览过

这几天了解了下关于mysql数据库的性优化和设计方面的内容,现在做一下自己学习的小结,后续我会继续深入学习,完善下总结: 1、使用索引 每张表最多可以做16个索引,支持多列索引和全文索引 建立索引:create index index_name on users(username); 查看索引

   这几天了解了下关于mysql数据库的性优化和设计方面的内容,现在做一下自己学习的小结,后续我会继续深入学习,完善下总结:

  1、使用索引

  每张表最多可以做16个索引,支持多列索引和全文索引

  建立索引:create index index_name on users(username);

  查看索引:show index from users;

  是一把双刃剑,建不建立索引,主要看表的功能,找好一个平衡点,。

  2、使用explain分析查询

  在查询在用explain

  explain select *from users;

  3、调整mysql内部配置

  (1)、改变索引缓冲区长度(key_buffer);

  推荐设置整个系统内存的25%。

  (2)、改变表长(read_buffer_size)

  当数据库对某个表进行频繁的扫描的时候,mysql会分配一段内存缓冲区,如果觉得扫描进行的太慢,可以适当将该值大小。

  (3)、设定打开表的数目的大小(table_cache)

  该变量控制mysql在任何时候打开表的最大数目,由此来控制服务器响应输入请求的能力。他跟max_connections

  (4)、对缓查询设定一个时间限制(long_query_time)

  ySQL带有“慢查询日志”,它会自动地记录所有的在一个特定的时间范围内尚未结束的查询。这个日志对于跟踪那些低效率或者行为不端的查询以及寻找优化对象都非常有用。long_query_time变量控制这一最大时间限定,以秒为单位。也可设置为ms,但是需要打补丁。

  至于安全方面的考虑,,比如测试数据库和线上分离、备份、主从等,这些后续再谈,时间紧迫,先写这么多,待续...

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!