mysql1215_这15条MySQL改善经验必须收藏
MySQL 作为目前的主流开源数据库, 既能挑战 “双11”,又能扛起 “618”,比起网红版数据库,MySQL 绝对是实力担当。
1、 为查询缓存优化查询
像 NOW() 和 RAND() 或是其它的诸如此类的SQL函数都不会开启查询缓存,谨慎使用
2、EXPLAIN 我们的SELECT查询(可以查看执行的行数)
可以让我们找到潜在的性能问题
3、当只要一行数据时使用LIMIT 1
MySQL数据库引擎会在查找到一条数据后停止搜索,而不是继续往后查询下一条符合条件的数据记录。
4、为搜索字段建立索引
在识别度高的列上建立正确的索引,以提升性能
5、在Join表的时候使用相当类型的列,并将其索引
关联表的关键字段,类型一致,字符集一致,才能提高性能,否则无法使用它们的索引
6、千万不要 ORDER BY RAND ()
执行RAND()函数(很耗CPU时间),会让你的数据库的性能呈指数级的下降
7、 避免SELECT *
从数据库里读出越多的数据,那么查询就会变得越慢。
8、永远为每张表设置一个ID
我们应该为数据库里的每张表都设置一个ID做为其主键,而且最好的是一个INT型的(推荐使用UNSIGNED),并设置上自动增加的 AUTO_INCREMENT标志。
9、可以使用ENUM 而不要VARCHAR
ENUM 类型是非常快和紧凑的。在实际上,其保存的是 TINYINT,但其外表上显示为字符串。
10、尽可能的使用NOT NULL
如果不是特殊情况,尽可能的不要使用NULL。在MYSQL中对于INT类型而言,EMPTY是0,而NULL是空值。而在Oracle中 NULL和EMPTY的字符串是一样的。NULL也需要占用存储空间,并且会使我们的程序判断时更加复杂。现实情况是很复杂的,依然会有些情况下,我们需要使用NULL值。
11、固定长度的表会更快
表中没有如下类型的字段: VARCHAR,TEXT,BLOB。只要我们包括了其中一个这些字段,那么这个表就不是“固定长度静态表”了,这样,MySQL 引擎会用另一种方法来处理。 固定长度的表会提高性能,因为MySQL搜寻得会更快一些,因为这些固定的长度是很容易计算下一个数据的偏移量的,所以读取的自然也会很快。
12、垂直分割
“垂直分割”是一种把数据库中的表按列变成几张表的方法,这样可以降低表的复杂度和字段的数目,从而达到优化的目的。
13、拆分打的DELETE或INSERT语句
这两个操作是会锁表的
14、越小的列会越快
对于大多数的数据库引擎来说,硬盘操作可能是最重大的瓶颈。越小的列消耗的io资源越少
15、选择正确的存储引擎
MyISAM是MYSQL5.5版本以前默认的存储引擎,基于传统的ISAM类型,支持B-Tree,全文检索,但是不是事务安全的,而且不支持外键。不具有原子性。支持锁表。
InnoDB是事务型引擎,支持ACID事务(实现4种事务隔离机制)、回滚、崩溃恢复能力、行锁。以及提供与Oracle一致的不加锁的读取方式。InnoDB存储它的表和索引在一个表空间中,表空间可以包含多个文件。
mysql1215_这15条MySQL改善经验必须收藏相关推荐
- Yoshua Bengio等大神传授:26条深度学习经验
Yoshua Bengio等大神传授:26条深度学习经验 发表于2015-09-17 08:21| 13482次阅读| 来源Marek Rei| 29 条评论| 作者Marek Rei 深度学习Pyt ...
- 谷歌机器学习规则:机器学习工程的43条最佳实践经验
文章选自Google Developers,作者:Martin Zinkevich. 机器学习目前已经有非常多的应用,它相比于传统的软件工程,最大的特点即我们编写的是学习过程,因此系统能根据数据改善性 ...
- 谷歌的15条招人秘诀
谷歌的15条招人秘诀 对于公司管理者而言,工作中最重要的事情是招聘人才.谷歌的管理者对每位面试者的态度都是一丝不苟的.无论面试者应聘的是初级软件工程师还是高级总经理,谷歌的面试官都会认真投入时间和 ...
- 19 条 MySQL 技巧,效率至少提高 3倍!
作者:喜欢拿铁的人 来源:https://zhuanlan.zhihu.com/p/49888088 本文我们来谈谈项目中常用的MySQL优化方法,共19条,具体如下: 1.EXPLAIN 做MySQ ...
- MySQL优化经验-值得细细品读
MySQL优化经验: 同时在线访问量继续增大 对于1G内存的服务器明显感觉到吃力严重时甚至每天都会死机 或者时不时的服务器卡一下 这个问题曾经困扰了我半个多月MySQL使用是很具伸缩性的算法,因此你通 ...
- mysql数据库优化课程---15、mysql优化步骤(mysql中最常用最立竿见影的优化是什么)...
mysql数据库优化课程---15.mysql优化步骤(mysql中最常用最立竿见影的优化是什么) 一.总结 一句话总结:索引优化最立竿见影 索引优化:不然有多少行要扫描多少次,1亿行大概是5到10分 ...
- 巧用这19条MySQL优化,效率至少提高3倍
本文我们来谈谈项目中常用的MySQL优化方法,共19条,具体如下: 1.EXPLAIN 做MySQL优化,我们要善用EXPLAIN查看SQL执行计划. 下面来个简单的示例,标注(1.2.3.4.5)我 ...
- sql查询前10条、第11条到第15条数据
SQL查询10条数据 查询前10条数据 查询第11条到第15条数据 查询前10条数据 MySQL.PostgreSQL使用limit select * from 表名 order by id(主键)l ...
- 15条建议,把技术成果写成一篇高质量学术论文
作者:汪晟 达摩院数据库与存储实验室 引言 随着技术的不断沉淀,研发团队对通过发表学术论文向业界分享研究成果的诉求也愈发强烈.但对许多研发团队而言,论文撰写的相关问题较难把握,例如:如何评估已取 ...
最新文章
- usaco frame up(所有拓扑排序的输出)
- php ? ? ?php ?
- AJAX与WebService
- setTimeout使用问题
- del rd命令行下删除文件不需要确认
- 将Java应用部署到SAP云平台neo环境的两种方式
- 计算机图形学图形旋转_计算机图形学翻译
- 计算机应用技术班级鉴定,大学班级的鉴定评语(精选50条)
- 0627-TP整理三(对表的操作,数据的显示)
- c语言小游戏代码大全300行,C语言贪吃蛇经典小游戏
- python shell清屏指令_python shell怎么清屏
- 如何复制百度文库的内容
- tf data 常用操作
- 学习oracle之后的感悟,学习培训后的收获和感想
- 新兴基金经理凯瑟琳·伍德ARKK基金在 2022 年初遭受新的打击
- 核磁共振成像读片指南(一)
- 笔记本(DELL Vostro 3549)为什么固态硬盘要装到光驱位置
- 烧写ARM板----MYS-6ULX
- 火狐,Firefox浏览器怎么设置主页
- YOLO系列:YOLO v3解析