MySQL数据库如何做好优化
2023-09-11 14:20:53 时间
碰到过好几次这样的题目,可每次都不能答的完全正确,现在大概列出如下:(望各位补充)
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的缓存中来的话,内存的带宽就成了瓶颈.
AfrikaansAlbanianArabicArmenianAzerbaijaniBasqueBengaliBelarusianBulgarianCatalanChinese (Simp)Chinese (Trad)CroatianCzechDanishDutchEnglishEsperantoEstonianFilipinoFinnishFrenchGalicianGeorgianGermanGreekGujaratiHaitian CreoleHebrewHindiHungarianIcelandicIndonesianIrishItalianJapaneseKannadaKoreanLaoLatinLatvianLithuanianMacedonianMalayMalteseNorwegianPersianPolishPortugueseRomanianRussianSerbianSlovakSlovenianSpanishSwahiliSwedishTamilTeluguThaiTurkishUkrainianUrduVietnameseWelshYiddish
华为大佬的“百万级”MySQL笔记,基础+优化+架构一键搞定 MySQL不用多说,大家都知道它是目前最为活跃热门的开源数据库,由于成本低,操作简易的特点,所以在互联网企业中被广泛使用,即使是头部的BATJ。由此可见,想要在互联网行业混得风生水起,或者说想要进入BATJ等一线互联网公司,那么熟练掌握MySQL必定是一块必要的敲门砖。
我又吊打面试官了,凭借MySQL海量数据优化(理论+实战) 朋友们,又见面了,上篇文章咱们讲到MySQL分库分表的方法,这篇文章咱们就针对上一篇文章模拟在MySQL中海量数据的优化方法,文章干货较多,建议三连。 提示:以下是本篇文章正文内容,案例仅供参考
AfrikaansAlbanianArabicArmenianAzerbaijaniBasqueBengaliBelarusianBulgarianCatalanChinese (Simp)Chinese (Trad)CroatianCzechDanishDutchEnglishEsperantoEstonianFilipinoFinnishFrenchGalicianGeorgianGermanGreekGujaratiHaitian CreoleHebrewHindiHungarianIcelandicIndonesianIrishItalianJapaneseKannadaKoreanLaoLatinLatvianLithuanianMacedonianMalayMalteseNorwegianPersianPolishPortugueseRomanianRussianSerbianSlovakSlovenianSpanishSwahiliSwedishTamilTeluguThaiTurkishUkrainianUrduVietnameseWelshYiddish
华为大佬的“百万级”MySQL笔记,基础+优化+架构一键搞定 MySQL不用多说,大家都知道它是目前最为活跃热门的开源数据库,由于成本低,操作简易的特点,所以在互联网企业中被广泛使用,即使是头部的BATJ。由此可见,想要在互联网行业混得风生水起,或者说想要进入BATJ等一线互联网公司,那么熟练掌握MySQL必定是一块必要的敲门砖。
我又吊打面试官了,凭借MySQL海量数据优化(理论+实战) 朋友们,又见面了,上篇文章咱们讲到MySQL分库分表的方法,这篇文章咱们就针对上一篇文章模拟在MySQL中海量数据的优化方法,文章干货较多,建议三连。 提示:以下是本篇文章正文内容,案例仅供参考
相关文章
- mysql数据库中,查看某个数据库下的表的存储类型都有哪些
- mysql数据库中,flush logs语句的作用是什么呢?
- MySQL数据库应用 2023-03-18
- mysql数据库遍历表,其一字段获取上一条数据
- 用navicat连接数据库报错:1130-host ... is not allowed to connect to this MySql server如何处理
- crly-shell centos/windows服务器,Mysql数据库表结构损坏
- 如何在Kubernetes上部署MySQL数据库
- windows python flask与mysql数据库写入查询
- 绝对干货,教你4分钟插入1000万条数据到mysql数据库表,快快进来
- mysql数据库提示本地无法连接远程服务器(Host is not allowed to connect to this MySQL server)解决办法
- mysql数据库中间件研究
- java jdbc使用SSH隧道连接mysql数据库demo
- 【数据库】MySQL主从复制以及读写分离实践
- MySQL 创建、查看创建语句、删除数据库、表
- python操作mysql数据库系列-操作MySql数据库(二)
- 【Node.js】学习Node.js简介、读取本地文件、连接数据库和MySQL常用查询命令(内附详细步骤)——学习Node.js
- MySQL数据库常见面试题总结
- MySQL数据库:游标Cursor
- jsp连接mysql数据库
- 图数数据库引擎tinkerpop(3) 使用java调用tinkerpop,存储到mysql数据库
- 设置如何远程连接mysql数据库
- mysql数据库增删改基础语句