首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql多个角度全面剖析sql优化

的优化是我们经常都会提到的一个话题,也是重中之重,在很多大厂中会有专门的DBA来做这件事情,甚至更过分的是连应届生的招聘岗位要求上都写了需要懂一点sql优化,最近moon一直在写关于mysql的文章,包括之前写的索引相关...正文 1.表结构优化● 优化sql最基本的条件时要有一张表,那么我们怎么通过一张表来达到sql语句优化的目的呢?...moon在之前的公司就有这样的问题,一条sql语句要连5张表,正常一个查询下来可能要1分多钟,所以这条sql太重了,而在moon的细心观察下发现,其中两张表都只用到了其中一个字段,然后我就和DBA商量下将这两个字段冗余到了其它的两个表中...(业务有关联),结果这条sql语句的执行时间就变成了十几秒。...2.2利用好mysql支持的索引下推,覆盖索引等功能 select a from user where b = 5; 此时给a和b字段增加索引,这样可以利用mysql的覆盖索引加速的功能,省去了回表的过程

77120
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql多个角度说明sql优化,让你吊打面试官!

    的优化是我们经常都会提到的一个话题,也是重中之重,在很多大厂中会有专门的DBA来做这件事情,甚至更过分的是连应届生的招聘岗位要求上都写了需要懂一点sql优化,最近moon一直在写关于mysql的文章,包括之前写的索引相关...正文 1.表结构优化● 优化sql最基本的条件时要有一张表,那么我们怎么通过一张表来达到sql语句优化的目的呢?...moon在之前的公司就有这样的问题,一条sql语句要连5张表,正常一个查询下来可能要1分多钟,所以这条sql太重了,而在moon的细心观察下发现,其中两张表都只用到了其中一个字段,然后我就和DBA商量下将这两个字段冗余到了其它的两个表中...(业务有关联),结果这条sql语句的执行时间就变成了十几秒。...2.2利用好mysql支持的索引下推,覆盖索引等功能 select a from user where b = 5; 此时给a和b字段增加索引,这样可以利用mysql的覆盖索引加速的功能,省去了回表的过程

    59730

    一次sql注入引发的多个mysql进程锁住的问题(针对myisam)

    以前碰到过一个sql注入式攻击引发大量mysql进程被锁住的例子,现在分享给大家。当时数据表用的是myisam存储引擎。...into myisam_test(v1,v2) select concat(v1,'a'),concat(v2,'b') from myisam_test; 接下来大boss上场了,就是那段被注入的sql...myisam_test where (id=1000) xor(if(453=453,sleep(5),0)) limit 1; 由于程序没有过滤非法参数值(xor(if(453=453,sleep(5),0))),sql...我们kill掉那条被注入的sql执行进程,锁立刻释放,后续的sql立刻返回结果。 ?...Sql注入式攻击再配合myisam的特性,导致大量进程处于等待状态,因此我们编程时基本的安全意识还是要有的,如净化用户输入,如使用如下参数化查询而不是将参数拼接到sql语句中: PreparedStatement

    1.1K80

    sql嵌套查询效率_sql嵌套查询返回多个字段

    太可怕了,前面的sql查询一小步,仅仅移动一个指针指向后面的下一条数据,就是后面所有查询条件的一大步 (外面的那个SELECT)到WHERE关键字的时候,又进入了另一个SQL语句中, 分析器先找到表...然后进入WHERE里分析里面的SQL语句,再把SC表装入内存,另一个指针(例如p2)指向SC表中的第一条记录,分析WHERE后面的条件表达式,依次进行分析,最后分析出一个虚表2。...(这也是为什么嵌套的SQL语句SELECT 后面为一般为的原因,因为它EXISTS返回的只是真或假,字段的名没有意义,用就行,当然用别的也不会错。...) 这里虽然嵌套的SQL语句分析完了,但主SQL语句只执行了一遍,也就是说p1指向Student的第一条记录,p1还要再指向Student表的下一条记录并分析,这样又进入了嵌套中的SQL语句,同上面说的一样分析...当p1也到了Student表的结尾,整个SQL语句结束。返回虚表1这一列。

    2.8K20

    MySQLSQL语言

    一、通用语法 SQL语句可以单行或多行书写,以分号结尾; SQL语句可以使用空格&缩进来增强语句的可读性; MySQL数据库的SQL语句不区分大小写,关键字建议使用大写; 注释: 单行注释...:–注释内容 或 #注释内容(MySQL特有) 多行注释:/*注释内容*/ 二、SQL语句分类 图片 1.DDL语句—数据库操作 查询 查询所有数据库SHOW DATABASES; 查询当前数据库...max、min、avg、sum) GROUP BY分组字段列表 HAVING分组后条件列表 排序查询 ORDER BY排序字段列表 分页查询 LIMIT分页参数 3.1.1 基本查询 查询多个字段...分页查询是数据库的“方言”,不同的数据库有不同的实现,MySQL中是LIMIT。 如果查询的是第一页数据,起始索引可以省略,直接简写为limit 10。...授予权限 GRANT 权限列表 ON 数据库名.表名 TO '用户名'@'主机名'; 4.2.4 撤销权限 REVOKE 权限列表 ON 数据库名.表名 FROM '用户名'@'主机名'; 注意: 多个权限之间

    2.2K40

    SQL -- MySQL 初识

    MySQL、Oracle、SQLServer是一个数据库软件,这些数据库软件支持标准SQL,也就是通过SQL可以使用这些软件,不过每一个数据库系统会在标准SQL的基础上扩展自己的SQL语法。...本文分享一下MySQL一些知识 MySQL MySQL介绍 MySQL数据库管理系统由瑞典的DataKonsultAB公司研发,该公司被Sun公司收购,现在Sun公司又被Oracle公司收购,因此MySQL...MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。...MySQL特点: MySQL数据库是用C和C++语言编写的,以保证源码的可移植性 支持多个操作系统例如:Windows、Linux、Mac OS等等 支持多线程,可以充分的利用CPU资源 为多种编程语言提供...Python语言等 MySQL优化了SQL算法,有效的提高了查询速度 MySQL开放源代码且无版权制约,自主性强、使用成本低。 MySQL历史悠久、社区及用户非常活跃,遇到问题,可以很快获取到帮助。

    1K50

    Mysql SQL优化

    SQL优化规则 第一条: 尽量全值匹配,也就是说尽量使用等于 第二条: 最佳左前缀原则 如果是复合索引,要遵守最佳左前缀原则,指的是从最左侧列开始并且不跳过索引中的列 如果是按顺序使用的索引列,且有最左侧的列...中间有范围查询会导致后面的索引列全部失效,但是本身是有效的 第五条: 尽量使用覆盖索引 尽量使用覆盖索引(只访问索引的查询(索引列和查询列一致)),减少select * 第六条: 尽量不使用不等于 mysql...pos from staffs where name like '%july%' 第九条: 字符串类型加引号 字符串不加单引号索引失效 解决方式:请加引号【捂脸】 第十条: OR改 UNION效率高 这个SQL...墙都不扶,就服你 全值匹配我最爱,最左前缀要遵守 带头大哥不能死,中间兄弟不能断 索引列上少计算,范围之后全失效 LIKE百分写最右,覆盖索引不写* 不等空值还有OR,,索引影响要注意 字符引号不能丢,SQL...作者:彼岸舞 时间:2020\07\11 内容关于:Mysql 本文来源于网络,只做技术分享,一概不负任何责任

    1K31
    领券