注册用户享全站资源 并成为粉丝 不定时福利发放
 

MySQL里面这五个非常非常有用的东西你知道吗?

17
发表时间:2018-11-30 11:08

摘要:MySQL是非常流行的关系型数据库,虽然拥有的SQL语法大部分是符合ANSI SQL标准的,但是它自身还是携带了很多优秀的、私有的语句和指示...

mysql优化

MySQL是非常流行的关系型数据库,虽然拥有的SQL语法大部分是符合ANSI SQL标准的,但是它自身还是携带了很多优秀的、私有的语句和指示符,今天我们就来分析一下。


EXPLAIN

当我们网站或者接口访问频率越来越大,这时如果我们的相关SQL语句执行时间很长的话,就很容易造成网站或者接口响应慢的情况,那么使用explain语句,我们能够清楚的知道MySQL是怎么执行我们的SQL语句的,执行某个查询语句总共查询了多少条记录,使用了什么表以及多表的链接顺序是怎么样的,该查询使用了哪些索引等等信息,有了这些信息,我们能够根据多次执行和分析优化我们的数据库,该建立索引的建索引,该删除的索引就删除掉。


FOR UPDATE

有时我们有这样的一种情况,就是需要将某个SELECT语句查询的行进行锁定,防止其他客户端修改,那么这个时候,我们可以使用这个指示符来完成。


DELAYED

有时发现我们的产品的某个插入、更新操作不需要立即生效,也就是一些对读要求高、写要求不太高的应用,可以使用这个指示符,就是将这个插入或者修改后的数据不是立即写入到磁盘文件中去,而是等到MySQL数据库非常空闲的时候再进行写入的操作,从这里来看,这个指示符也算是一个小的优化性指示符。


SQL_CACHE

有时我们的产品读操作非常多,修改频率比较低,那么这个时候我们能够在执行select查询的时候指定sql_cache这个指示符,这样该查询语句和相应的查询结果将被缓存起来,那么下次执行同样的查询语句时,如果数据没有发生改变,那么将直接返回这个缓存的结果给客户端,从这里来看,这个查询语句指示符主要用于一些特性应用场景的优化操作。


ON DUPLICATE KEY UPDATE

我们知道,在MySQL中有一个特殊的语句就是Replace语句,就是当插入的时候,我们发现某个条件(这里需要注意的是,这里指的是唯一索引或主键)的数据已经存在了,那么这个时候就先删除这条数据,然后再插入新的数据,也就是先删除再插入,但是有时候我们仅仅需要的是,如果存在了仅仅修改某个字段的值,而不是删除再插入,那么这个时候可以使用ON DUPLICATE KEY UPDATE来完成。

合理用好上面介绍的知识,一定能够解决MySQL中的大部分问题,包括部分性能的分析和优化。


文章分类: MySQL
分享到:
会员登录

会员登录

登录免费下载全站资源

获取验证码
登录
登录
开发简历

开发简历

简历模板网站自取

入坑需谨慎

入坑需谨慎

高薪完全靠自己

微信赞助-Java帮帮社区

微信赞助-Java帮帮社区

非盈利性学习社区

支付宝赞助-Java帮帮社区

支付宝赞助-Java帮帮社区

将分享做到极致

大公司资讯
文章附图

近日,在美国推出满一年的Facebook视频服务Watch,宣布正式向全球推广,这预示着视频领域中,YouTube...

文章附图

据彭博社北京时间9月19日报道,科技行业最引人注目的法律大战可能正在进入尾声。据高通CEO史蒂夫·莫伦科夫(Ste...

Java帮帮公众号生态

Java帮帮公众号生态

总有一款适合你

Java帮帮-微信公众号

Java帮帮-微信公众号

将分享做到极致

Python帮帮-公众号

Python帮帮-公众号

人工智能,爬虫,学习教程

大数据驿站-微信公众号

大数据驿站-微信公众号

一起在数据中成长

九点编程-公众号

九点编程-公众号

深夜九点学编程

程序员服务区-公众号

程序员服务区-公众号

吃喝玩乐,听学吐画

Java帮帮学习群生态

Java帮帮学习群生态

总有一款能帮到你

Java学习群

Java学习群

与大牛一起交流

大数据学习群

大数据学习群

在数据中成长

九点编程学习群

九点编程学习群

深夜九点学编程

python学习群

python学习群

人工智能,爬虫

测试学习群

测试学习群

感受测试的魅力

Java帮帮生态承诺

Java帮帮生态承诺

一直坚守,不负重望

初心
勤俭
诚信
正义
分享
合作品牌 非盈利生态-优质内容分享传播者
关于我们
友链申请
友链交换:加帮主QQ2524138991 留言即可 24小时内答复  
全站内容非商业用途,内容来源于网友,并遵循 CC BY-NC 4.0 许可,如有异议请联系客服。
会员登录
获取验证码
登录
登录
我的资料
留言
回到顶部