• 高性能MySQL笔记-第5章Indexing for High Performance-004怎样用索引才高效


    一、怎样用索引才高效

    1.隔离索引列

    MySQL generally can’t use indexes on columns unless the columns are isolated in the query. “Isolating” the column means it should not be part of an expression or be inside a function in the query.

    如,以下的查询不能用actor_id索引

    SELECT actor_id FROM sakila.actor WHERE actor_id + 1 = 5;

    这个也不能应用索引

    1 SELECT ... WHERE TO_DAYS(CURRENT_DATE) - TO_DAYS(date_col) <= 10;

    2.给长文本加上前缀索引

     1 -- 示范以列的部分前缀来建索引,首先找出数量最多的列和最常查询的列
     2 CREATE TABLE sakila.city_demo(city VARCHAR(50) NOT NULL);
     3 INSERT INTO sakila.city_demo(city) SELECT city FROM sakila.city;
     4 -- Repeat the next statement five times:
     5 INSERT INTO sakila.city_demo(city) SELECT city FROM sakila.city_demo;
     6 -- Now randomize the distribution (inefficiently but conveniently):
     7 UPDATE sakila.city_demo
     8 SET city = (SELECT city FROM sakila.city ORDER BY RAND() LIMIT 1);
     9 
    10 SELECT COUNT(*) AS cnt, city FROM sakila.city_demo GROUP BY city ORDER BY cnt DESC LIMIT 10;
    11 
    12 SELECT COUNT(*) AS cnt, LEFT(city, 3) AS pref FROM sakila.city_demo GROUP BY pref ORDER BY cnt DESC LIMIT 10;
    13 
    14 SELECT COUNT(*) AS cnt, LEFT(city, 7) AS pref FROM sakila.city_demo GROUP BY pref ORDER BY cnt DESC LIMIT 10;
    15 
    16 --to find the full column’s selectivity:
    17 SELECT COUNT(DISTINCT city)/COUNT(*) FROM sakila.city_demo;
    18 
    19 -- to find the selectivity of several prefix lengths in one query:
    20 
    21 SELECT COUNT(DISTINCT LEFT(city, 3))/COUNT(*) AS sel3,
    22 COUNT(DISTINCT LEFT(city, 4))/COUNT(*) AS sel4,
    23 COUNT(DISTINCT LEFT(city, 5))/COUNT(*) AS sel5,
    24 COUNT(DISTINCT LEFT(city, 6))/COUNT(*) AS sel6,
    25 COUNT(DISTINCT LEFT(city, 7))/COUNT(*) AS sel7
    26 FROM sakila.city_demo;
    27 
    28 ALTER TABLE sakila.city_demo ADD KEY (city(7));

    缺点:

    Prefix indexes can be a great way to make indexes smaller and faster, but they have downsides too: MySQL cannot use prefix indexes for ORDER BY or GROUP BY queries, nor can it use them as covering indexes.
    A common case we’ve found to benefit from prefix indexes is when long hexadecimal identifiers are used.

    3.Multicolumn Indexes  

    When you see an index merge in EXPLAIN , you should examine the query and table structure to see if this is really the best you can get. You can disable index merges with the optimizer_switch option or variable. You can also use IGNORE INDEX

    4.Choosing a Good Column Order

     1 -- 选择正确的列顺序作索引
     2 SELECT SUM(staff_id = 2), SUM(customer_id = 584) FROM paymentG
     3 SELECT SUM(staff_id = 2) FROM payment WHERE customer_id = 584G
     4 SELECT COUNT(DISTINCT staff_id)/COUNT(*) AS staff_id_selectivity,
     5 COUNT(DISTINCT customer_id)/COUNT(*) AS customer_id_selectivity,
     6 COUNT(*)
     7 FROM paymentG
     8 
     9 ALTER TABLE payment ADD KEY(customer_id, staff_id);
    10 
    11 SELECT COUNT(DISTINCT threadId) AS COUNT_VALUE
    12 FROM Message
    13 WHERE (groupId = 10137) AND (userId = 1288826) AND (anonymous = 0)
    14 ORDER BY priority DESC, modifiedDate DESC
    15 
    16 SELECT COUNT(*), SUM(groupId = 10137),
    17 SUM(userId = 1288826), SUM(anonymous = 0)
    18 FROM MessageG

    5.等。。。。

     

  • 相关阅读:
    win7下安装配置tomcat,java运行环境
    Ubuntu 12.10安装配置JDK7环境
    全面介绍Linux终端命令
    Ubuntu 配置 Tomcat
    Linux手动导入导出mysql数据库
    navicat数据库管理软件(支持mysql,oracle,sqlserver,sqlite,postgreSQL)
    信号量(semaphore)和互斥量(mutex)
    最新版fcitx 4.1.2源码编译安装(ubuntu 10.04)
    Groovy动态语言简介
    读书笔记:《java脚本编程:语言、框架与模式》(2)jvm内部的脚本语言
  • 原文地址:https://www.cnblogs.com/shamgod/p/5383255.html
Copyright © 2020-2023  润新知