MySQL数据库如何做好优化

(碰到过好几次这样的题目,可每次都不能答的完全正确,现在大概列出如下:(望各位补充)
(1.数据库的设计
((尽量把数据库设计的更小的占磁盘空间。
(1).尽可能使用更小的整数类型。(mediumint就比int更合适)。
(2).尽可能的定义字段为not null,除非这个字段需要null。
(3).如果没有用到变长字段的话比如varchar,那就采用固定大小的纪录格式比如char。
(4).表的主索引应该尽可能的短,这样的话每条纪录都有名字标志且更高效。
(5).只创建确实需要的索引。索引有利于检索记录,但是不利于快速保存记录。如果总是要在表的组合字段上做搜索,那么就在这些字段上创建索引。索引的第一部分必须是最常使用的字段。如果总是需要用到很多字段,首先就应该多复制这些字段,使索引更好的压缩。
(6).所有数据都得在保存到数据库前进行处理。
(7).所有字段都得有默认值。
(8).在某些情况下,把一个频繁扫描的表分成两个速度会快好多。在对动态格式表扫描以取得相关记录时,它可能使用更小的静态格式表的情况下更是如此。
(2.系统的用途
(1).尽量使用长连接。
(2).explain 复杂的SQL语句。
(3).如果两个关联表要做比较话,做比较的字段必须类型和长度都一致。
(4).LIMIT语句尽量要跟 order by 或者 distinct。这样可以避免做一次full table scan。
(5).如果想要清空表的所有纪录,建议用 truncate table tablename 而不是 delete from tablename。
(6).能使用 STORE PROCEDURE 或者 USER FUNCTION的时候。
(7).在一条insert语句中采用多重纪录插入格式,而且使用 load data infile 来导入大量数据,这比单纯的indert快好多。
(8).经常 OPTIMIZE TABLE 来整理碎片。
(9).还有就是 date 类型的数据如果频繁要做比较的话尽量保存在 unsigned int 类型比较快。
(3.系统的瓶颈
(1).磁盘搜索
((并行搜索,把数据分开存放到多个磁盘中,这样能加快搜索时间.
(2).磁盘读写(IO)
((可以从多个媒介中并行的读取数据。
(3).CPU周期
((数据存放在主内存中,这样就得增加CPU的个数来处理这些数据。
(4).内存带宽
((当CPU要将更多的数据存放到CPU的缓存中来的话,内存的带宽就成了瓶颈.

转载于:https://blog.51cto.com/jinyan2049/1422125

MySQL数据库如何做好优化相关推荐

  1. mysql 删除多余帐号_安装完mysql数据库后的优化(删除多余用户和数据库)

    安装完mysql数据库后的优化(删除多余用户和数据库) 发布时间:2020-06-27 19:09:35 来源:51CTO 阅读:2761 作者:冰冻vs西瓜 栏目:数据库 1.查看数据库的版本信息: ...

  2. 高并发大流量专题---10、MySQL数据库层的优化

    高并发大流量专题---10.MySQL数据库层的优化 一.总结 一句话总结: mysql先考虑做分布式缓存,过了缓存后就做mysql数据库层面的优化 1.mysql数据库层的优化的前面一层是什么? 数 ...

  3. MySQL数据库SQL层级优化

    MySQL数据库SQL层级优化 本篇主涉及MySQL SQL Statements层面的优化. 首先,推荐一个链接为万物之始:http://dev.mysql.com/doc/refman/5.0/e ...

  4. 读《深入浅出MySQL数据库开发、优化与管理维护(第2版)》笔记2 WITH ROLLUP关键字

    读<深入浅出MySQL数据库开发.优化与管理维护(第2版)>笔记2 WITH ROLLUP关键字 WITH ROLLUP是可选语法,表名是否对分类聚合后的结果进行再汇总; 我自己的使用实例 ...

  5. MySQL数据库与SQL优化

    一.MySQL 数据库与 SQL 优化 1.结构图 二.MySQL 数据库引擎简介 1.ISAM(IndexedSequentialAccessMethod)     ISAM 是一个定义明确且历经时 ...

  6. mysql query 优化_第 8 章 MySQL 数据库 Query 的优化

    前言: 在之前"影响 MySQL 应用系统性能的相关因素"一章中我们就已经分析过了Query语句对数据库性能的影响非常大,所以本章将专门针对 MySQL 的 Query 语句的优化 ...

  7. MySQL数据库:SQL优化与索引优化

    一.索引优化: 1.like语句的前导模糊查询不使用索引: select * from doc where title like '%XX':   --不能使用索引 select * from doc ...

  8. MySQL数据库的性能优化总结

    一.MySQL数据库的优化目标.基本原则: 1.优化目标: MySQL数据库是常见的两个瓶颈是CPU和I/O的瓶颈,无论是索引优化.还是表结构优化,参数优化,最后都可以归纳到这这两个分类中: (1)减 ...

  9. 针对Mysql数据库服务器的优化

    Mysql 数据库的优化 最近一直在搞Mysql数据库的配置和优化,下面记录一下这些天研究的结果,以方便以后查看. 一.服务器的硬件的优化 对mysql服务器来说主要从以下几个方面来考虑: 1.磁盘寻 ...

最新文章

  1. 史上首次,强化学习算法控制核聚变登上Nature:DeepMind让人造太阳向前一大步...
  2. TFTP、RAM、NVRAM之间的关系
  3. Head first java chapter 6 认识java API
  4. 日常生活中的法语积累2
  5. android编程中setLayoutParams方法设置
  6. 在线日志文件丢失的恢复(笔记)
  7. logback AbstractLogstashTcpSocketAppender 源码解析
  8. 【嵌入式Linux】嵌入式Linux应用开发基础知识之网络通信
  9. 如何在DOS系统中进入phpStudy的MySQL ?
  10. 计算机应用基础南丁格尔,关于单元基础训练的习题
  11. Forcing close of thread
  12. 纵向表格转为横向表格
  13. 虚拟机下NAT 和 桥接模式 联网操作
  14. 如何使用物联网低代码平台进行设备调试?
  15. ROC曲线的通俗理解
  16. 【第59篇】MetaFormer实际上是你所需要的视觉
  17. 计算长方体体积(3分)
  18. socket 科普文章
  19. 网易云音乐搜索引擎 python+whoosh---(2)搜索引擎
  20. 通过J-Flash回读取芯片的固件程序

热门文章

  1. MyBatis接口代理
  2. python history文件_【python之路19】文件操作
  3. java 验证码 添加背景图_java登陆界面怎么加背景图 会的我加你
  4. Delphi获得计算机系统配置,用Delphi获取本地计算机名称和IP地址
  5. stderr java_如何使用Log4j将stdout和stderr写入/捕获到文件并使用Windows和Tomcat 5.5(Java)?...
  6. 2021快手短剧数据报告
  7. 碳达峰、碳中和带来的机遇和挑战研究报告
  8. 全面解码美妆消费者心智
  9. python装饰器函数执行后日志_一篇文章搞懂Python装饰器所有用法
  10. 作者:牛新(1983-),男,博士,国防科学技术大学并行与分布处理重点实验室助理研究员...