zoukankan      html  css  js  c++  java
  • 面试DB优化

    高频全表扫描

    0.5

    表大小超过200M,且SQL高频执行(15分钟内超过500次),PIR 3级,表大小超过高速缓存的1.5%,报PIR 2级。

    禁止使用select *

    0.5

    禁止使用select * ,必须明确选择所需的列,每句SQL扣0.5分。

    禁止出现重复查询子句

    0.5

    可以使用with as替换子句来提升SQL语句执行效率,每句SQL扣0.5分。

    索引列函数

    0.5

    在查询索引列上发生函数调用(函数索引除外),每次扣0.5分。

    update禁止出现order by子句

    0.5

    防止DML过程出现不必要的排序,每句SQL扣0.5分。

    update必须出现where子句

    1.0

    防止DML过程出现全表锁,每句SQL扣1分。

    禁止更新主键列值

    1.0

    不允许有SQL更新主键,每次SQL扣1分。

    禁止嵌套select子句

    0.5

    防止出现select子句的嵌套子查询,避免出现性能问题,每句SQL扣0.5分。

    delete必须出现where子句

    1.0

    防止DML过程出现全表锁,每句SQL扣1分。

    delete禁止出现order by子句

    1.0

    防止DML过程出现不必要的排序,每句SQL扣0.5分。

    索引全扫

    0.1

    执行计划里有INDEX FULL SCAN操作,每次扣0.1分。

    索引跳跃

    0.2

    执行计划里有INDEX SKIP SCAN操作,每次扣0.2分。

    全表扫描

    0.5

    对于大于200M的表全表扫描,执行计划里有TABLE ACCESS FULL操作,每次扣0.5分。

    笛卡尔积

    1.0

    缺少连接条件,导致SQL使用笛卡尔积的方式进行连接,每句SQL扣1分。

    嵌套连接过深

    1.0

    执行计划中嵌套连接深度超过6层,每句SQL扣1分。

    绑定变量

    0.2

    未使用绑定变量的SQL,每句SQL扣0.2分。

    隐式转换

    0.5

    在查询列上发生隐式转换,每次扣0.5分。

  • 相关阅读:
    linux上mysql安装详细教程
    druid部署
    druid.io本地集群搭建 / 扩展集群搭建
    CentOS7.1.x+Druid 0.12 集群配置
    Python小项目四:实现简单的web服务器
    hadoop学习---运行第一个hadoop实例
    Hadoop集群完全分布式坏境搭建
    mysql备份与恢复
    mysql登录的三种方式
    nginx代理,负载均衡
  • 原文地址:https://www.cnblogs.com/panxuejun/p/8621668.html
Copyright © 2011-2022 走看看