关于mysql的优化
MYSQL的优化一个很棘手的问题,也是一个公司最想处理得当的问题.
那么今天,本人为大家带来几点优化数据库的方法:
1.选取最适用的字段属性
一般来说,数据库的的表越小,在其上面执行的查询也会越快.因此,我们在设计表的时候可以将表中的宽度设的尽可能的小.
对于字段来说,,我们尽量和值为NOT NULL,这样在查询时,数据库不用比较NULL值
对于某些文本字段,可以用ENUM类型来对该字段下的数值进行限制.
2.使用JOIN来代替子查询
了解mysql的人都知道,使用子查询可以一次性的完成很多逻辑上的需要多个复杂步骤才能完成的SQL操作,但是这样的查询会大大降低查询的速率
如果使用JOIN来完成此项工作的话,速度会快很多.
JOIN之所以效率很高.是因为MYSQL不需要在内存中创建临时表来完成这个逻辑上的两个步骤的查询工作.
3.UNION来代替手动创建的临时表
mysql从4.0版本开始支持联合查询.
它可以把需要使用临时表的两条或更多的select查询合并的一个查询中,在客户端的查询会话结束的时候,临时表会自动删除
从而保证数据库整齐,高效.
4.事务
尽管使用子查询,JOIN和UNION来创建各种查询.但并不是所有的操作都可以用一条或几条SQL语句就可以完成的
为了防止数据库出现意外.就要使用事务,推荐使用InnoDB引擎
其作用是可以保持数据库数据的一致性和完整性.
另一个作用则是在多个用户同时使用相同的数据源时,它可以锁定数据库的方法来为童虎提供一种安全的访问方式
5.锁定表
事务虽好,可由于它的独占性,有时会影响数据库的性能.假设有成千上万的用户同时访问一个数据库,就会产生比较严重的响应延迟
那么锁定表,就可以起到维护数据完整性的作用,来获得更好的性能.
6.使用外键
锁定表也有它的弊端,那就是它不能保证数据的关联性.这个时候,我们就可以使用外键.
注意,引擎要用innodb而不是myisam类型
7.使用索引
索引是提高数据性能的常用方法,它可以令数据库服务器以比没有索引快的多的速度检索特定的行,尤其是在查询语句中包含MAX(),MIN()和ORDER BY 这些命令的时候,性能提高更为明显.
一般来说,索引应建立在那些用于JOIN ,WHERE 判断 和ORDER BY 排序的字段上,尽可能不要对数据库中某个含有大量重复值的字段建立索引.
8.优化的查询语句
绝大多数下,用索引可以提高查询的速度,但是如果SQL语句使用不恰当的话,索引将无法发挥作用.
那么该注意以下几个方面:
1.最好在相同类型的字段间进行比较的操作
2.在建有索引的字段上尽量不要使用函数进行操作.
3.在搜索字符型字段时,我们有时会使用LIKE关键字和通配符,这种做法虽然简单,但也是以牺牲系统性能为代价的操作.
最后,应该注意避免在查询中让MYSQL进行自动类型转换,因为转换过程也会让索引变得不起作用!
以上,就是我为大家总结的几点关于优化数据库的操作,仅供参考,若有雷同,实属巧合!
------作者 恋夏啊 2019-1-3
关于mysql的优化的更多相关文章
- Mysql - 性能优化之子查询
记得在做项目的时候, 听到过一句话, 尽量不要使用子查询, 那么这一篇就来看一下, 这句话是否是正确的. 那在这之前, 需要介绍一些概念性东西和mysql对语句的大致处理. 当Mysql Server ...
- Mysql性能优化三(分表、增量备份、还原)
接上篇Mysql性能优化二 对表进行水平划分 如果一个表的记录数太多了,比如上千万条,而且需要经常检索,那么我们就有必要化整为零了.如果我拆成100个表,那么每个表只有10万条记录.当然这需要数据在逻 ...
- Mysql性能优化一
下一篇:Mysql性能优化二 mysql的性能优化无法一蹴而就,必须一步一步慢慢来,从各个方面进行优化,最终性能就会有大的提升. Mysql数据库的优化技术 对mysql优化是一个综合性的技术,主要包 ...
- 关于MySQL数据库优化的部分整理
在之前我写过一篇关于这个方面的文章 <[原创]为什么使用数据索引能提高效率?(本文针对mysql进行概述)(更新)> 这次,主要侧重点讲下两种常用存储引擎. 我们一般从两个方面进行MySQ ...
- [MySQL性能优化系列]提高缓存命中率
1. 背景 通常情况下,能用一条sql语句完成的查询,我们尽量不用多次查询完成.因为,查询次数越多,通信开销越大.但是,分多次查询,有可能提高缓存命中率.到底使用一个复合查询还是多个独立查询,需要根据 ...
- [MySQL性能优化系列]巧用索引
1. 普通青年的索引使用方式 假设我们有一个用户表 tb_user,内容如下: name age sex jack 22 男 rose 21 女 tom 20 男 ... ... ... 执行SQL语 ...
- 【MySQL】花10分钟阅读下MySQL数据库优化总结
1.花10分钟阅读下MySQL数据库优化总结http://www.kuqin.com2.扩展阅读:数据库三范式http://www.cnblogs.com3.my.ini--->C:\Progr ...
- MySQL性能优化:索引
MySQL性能优化:索引 索引提供指向存储在表的指定列中的数据值的指针,然后根据您指定的排序顺序对这些指针排序.数据库使用索引以找到特定值,然后顺指针找到包含该值的行.这样可以使对应于表的SQL语句执 ...
- 30多条mysql数据库优化方法,千万级数据库记录查询轻松解决(转载)
1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索 ...
- mysql 性能优化方向
国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...
随机推荐
- ZROJ#398. 【18提高7】随机游走(期望dp 树形dp)
题意 [题目链接]版权原因就不发了.. 给出一棵树,求出任意两点之间期望距离的最大值 Sol 比较清真的一道题吧.. 设\(f[x]\)表示从\(x\)走到\(x\)的父亲的期望步数 \(g[x]\) ...
- Homebrew 的使用
安装 /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/ins ...
- PLSQL Developer乱码
1.select * from v$nls_parameters 查询nls的参数,获得数据库服务器端的字符编码 NLS_LANGUAGE NLS_CHARACTERSET 2.修改本地环境变量,设置 ...
- libcurl 中使用curl_multi_perform()函数执行订阅类型url的问题
前提概要 当需要同时处理多个url时,可采用curl_multi_perform方式执行,如下代码1: //初始化一个multi curl 对象 CURLM * curl_m = curl_multi ...
- linux常用指令集-持续更新...
0.查看所有java进程GC情况:for i in `jps|egrep -v "Jps|Launcher" |cut -d" " -f1`;do pwdx $ ...
- Android使用Fragment来实现TabHost的功能
http://www.cnblogs.com/tiantianbyconan/p/3360938.html 好了,到此为止,我们已经用Fragment实现了类似TabHost的功能了,下面来看下各个F ...
- 并发包java.util.concurrent.CountDownLatch
/** * * @描述: 倒计时器 . * 犹如倒计时计数器,调用CountDownLatch对象的countDown方法就将计数器减1,当计算器为0的时候 * 则所有等待者或单个等待者开始执行 * ...
- Linux中基于apache httpd的svn服务器搭建与配置
mod_dav_svn是apache连接svn的模块 yum install subversion mod_dav_svn httpd 配置文件简单说明, SVNParentPath 说明可以在指定的 ...
- 免费的SSL证书,你值得拥有!Let's Encrypt 试用体验记录
早上收到 Let’s Encrypt 的邮件,说偶之前申请的已经通过了,于是马上开始试用.Let’s Encrypt 是一个新的数字证书认证机构,它通过自动化的过程消除创建和安装证书的复杂性,为网站提 ...
- Orchard Core 文档翻译 (七)Contents
CMS Modules »Contents Contents (OrchardCore.Contents) 此模块提供内容管理服务. Liquid 您可以使用“content ”属性从liquid 视 ...