8.2.1 Optimizing SELECT Statements
8.2.2 Optimizing Data Change Statements
8.2.3 Optimizing Database Privileges
8.2.4 Optimizing INFORMATION_SCHEMA Queries
8.2.5 Other Optimization Tips 一个核心的数据库应用逻辑是通过SQL语句执行,直接通过一个解释器或者通过一个API提交。 调优原则在这个章节是帮助加快各种类型的MySQL 应用。指导方针覆盖SQL操作 读和写数据, 后台负载对于SQL操作,操作被用于特定的场景比如数据库监控 8.2.1 Optimizing SELECT Statements 优化SELECT 语句 查询,以SELECT 语句的形式, 执行所有的查询操作在数据库。 调优那些操作是重中之重, 无论是完成秒级响应对于动态的web页面, 或者需要数小时来产生巨大的隔夜报告 除了SELECT 语句,调整基数对于查询也应用与比如CREATE TABLE...AS SELECT, INSERT INTO...SELECT, and WHERE clauses in DELETE statements. 那些语句有额外的性能考虑因为它们组合了写操作和读查询操作 8.2.1.1 Speed of SELECT Statements 加速SELECT 语句 优化查询的主要考虑因素是: 1. 让一个慢的 SELECT ... WHERE 查询的更快,第一件事情是检查是否你能增加索引。 设置indexes 在列用于WHERE 子句,来加速评估,过滤,和最后的检索结果。 来避免浪费磁盘空间,构造一个小的索引集来加速很多相关的查询在你的应用里 索引是尤其重要的对于查询 涉及不同的表,使用功能比如关联和外键。 你可以使用EXPLAIN 语句来决定 使用哪个索引用于查询 2. 隔离和调整查询的任何部分,比如 一个函数调用, 会消耗执行时间。 取决于查询是如何构建的,一个函数可以在结果集中的每行都调用一次,甚至 表里每一行都调用一次,大大的降低效率 3.减少 全表扫描数量在你的查询里,特别是对于大的表 4. 保持表的统计信息是新的通过使用ANALYZE TABLE 语句周期性的,这样优化器有构造一个有效的查询执行计划的信息 5.了解调优技巧,索引技术,配置参数,特定的存储引擎对于每个表 InnoDB和MyISAM 有参考设置对于启动和维持高性能在查询里 6.特别的,在MySQL 5.6.4和以上版本, 你可以优化单个查询事务对于InnoDB表 7.避免改变查询方式 会让它很难理解,尤其是如果优化器做了一些相同的转换 8.如果一个性能问题不是容易解决的通过基本参考, 调查特定查询的内容细节,通过阅读执行计划和调整你的索引,WHERE 子句,关联子句等等 (当你达到一定的专业水平,读取执行计划可能是你对于每个查询的第一步) 9. 调整 内存区域的大小和属性用于cache, 有效的使用InnoDB buffer pool,MyISAM key cache,和MySQL query cache, 重复查询运行更快因为结果是从内存里检索第2次和随后的时间 10.即使对于一个查询 使用cache 内存区域很快,你仍可能进一步优化 它们使用更少的内存, 让你的应用更加的可扩展性。可扩展性意味着 你的应用可以处理更多的并发用户,大的请求,而不需要经历性能的大幅下降 11. 处理locking 问题, 你的查询的速度可能被其他session 同时访问表有影响

8.2.1.1 Speed of SELECT Statements 加速SELECT 语句的更多相关文章

  1. Laravel - Union + Paginate at the same time? and another problem----1222 The used SELECT statements have a different number of columns (SQL: (select count(*) as aggregate from

    ### 这是这几天,碰到的一个比较头疼的问题 使用union all联合查询,同时laravel 生成分页,但发生报错? QueryException : SQLSTATE The used from ...

  2. Go语言规格说明书 之 select语句(Select statements)

    go version go1.11 windows/amd64 本文为阅读Go语言中文官网的规则说明书(https://golang.google.cn/ref/spec)而做的笔记,介绍Go语言的 ...

  3. MySQL: Speed of INSERT Statements

    Speed of INSERT Statements To optimize insert speed, combine many small operations into a single lar ...

  4. The used SELECT statements have a different number of columns???

    今天我们组就我一个人留守在这里修复bug了,有点小悲伤啊,他们都问我能不能hold得住啊,我当然能hold得住啊: 在看一个入库的存储过程中,在数据库运行的时候是没问题的,项目已启动,进行入库操作就是 ...

  5. Mysql -- The used SELECT statements have a different number of columns

    这是因为使用union的两个SQL语句产生的记录的表结构不一致. 必须是结构完全一致的记录集合才可以使用UNION. 以上就是两个表的字段不一样,导致,所以大家可以检查下. 可以 将 select * ...

  6. string strSQL = "Select * From Employees;Select * from Customers";执行两次查询

    SqlCommand对象的字符串SQL命令可以做多个,以查询为例,用到SqlDataReader的一些方法,如ExecuteReader(),Read()(一条命令内的移动至下一记录),NextRes ...

  7. select count(*)和select count(1)

    一般情况下,Select Count (*)和Select Count(1)两着返回结果是一样的 假如表沒有主键(Primary key), 那么count(1)比count(*)快, 如果有主键的話 ...

  8. select count(*)和select count(1)的区别

    一般情况下,Select Count (*)和Select Count(1)两着返回结果是一样的 假如表沒有主键(Primary key), 那么count(1)比count(*)快, 如果有主键的話 ...

  9. 仅Firefox中A元素包含Select时点击Select不能选择option

    这是在使用京东的一个日期组件时碰到的bug,重现bug的代码精简如下 <!DOCTYPE HTML> <html> <head> <title> 仅Fi ...

随机推荐

  1. qt之treeview例子

    # -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' from PyQt4.Qt import * from PyQt4. ...

  2. ASIHTTPRequest 详解 例子

    目录 目录 发起一个同步请求 创建一个异步请求 队列请求 请求队列上下文 ASINetworkQueues, 它的delegate提供更为丰富的功能 取消异步请求 安全的内存回收建议 向服务器端上传数 ...

  3. C++中的构造函数和析构函数

    构造函数: 在类实例化对象时自动执行,对类中的数据进行初始化.构造函数可以从载,可以有多个,但是只能有一个缺省构造函数. 析构函数: 在撤销对象占用的内存之前,进行一些操作的函数.析构函数不能被重载, ...

  4. [转] Ubuntu 12.04下LAMP安装配置 (Linux+Apache+Mysql+PHP)

    我是一个Linux新手,想要安装一台Ubuntu 12.04版的Linux服务器,用这台服务器上的LAMP套件来运行我自己的个人网站.LAMP套件就是 “Linux+Apache+Mysql+PHP这 ...

  5. linux中切换用户方式su和su -的区别

    Using su The  su  command allows users to open a terminal window, and from that terminal start a sub ...

  6. div中实现居中

    今天纠结了大半天的居中,把学到的先记录下来,还没完全弄清楚,发现网上原创的技术贴并不算多,大多都是相互转载.(ps.先安利一个大神的帖集,昨天才发现的,内容丰富,语言,呃...很幽默,一般都是图文并茂 ...

  7. HTML5中class选择器属性的解释

    设置有class属性值的元素,可以被css中的选择器调用,也可以在javascript中以getElementsByClassName()方法调用. 可以给各个元素添加class而且名称可以相同与id ...

  8. Java的native关键字---JAVA下调用其他语言的关键词

    今天研究Java基础类库,Object类的时候,发现了一个关键字:native 咦?这是个什么东东?它认识我,我可不认识它! 嘿嘿,没关系,baidu一下. java native关键字 一. 什么是 ...

  9. Android学习手记(2) Activity生命周期

    1. 单个Activity的生命周期 当只有一个Activity的时候, 首先执行onCreate->onStart->onResume. 这时, 窗口便显示在屏幕上了. 然后我们按返回键 ...

  10. linux 分区

    1.硬盘分区分为基本分区和扩展分区, 扩展分区分下去就是逻辑分区,而且逻辑分区没有数量上的限制. 2.查看linux系统分区具体情况 fdisk - l 3.查看某个目录是哪个分区下的 df /boo ...