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分。

  • 相关阅读:
    逻辑学的基本运算
    第一性原理:First principle thinking是什么?
    人类认识的基本技能
    编程的本质:简化+抽象+再现
    区块链
    信号、系统、传递、树
    MVVM
    数据驱动 状态驱动
    事件与状态机 事件驱动编程
    数据一致性举例:登录系统
  • 原文地址:https://www.cnblogs.com/panxuejun/p/8621668.html
Copyright © 2011-2022 走看看