保护索引要注意的问题「建议收藏」

保护索引要注意的问题

大家好,又见面了,我是全栈君。

1. IS NULL 与 IS NOT NULL



        不能用null作索引。不论什么包括null值的列都将不会被包括在索引中。

即使索引有多列这种情况下,仅仅要这些列中有一列含有null。该列就会从索引中排除。

也就是说假设某列存在空值,即使对该列建索引也不会提高性能。
  不论什么在where子句中使用is null或is not null的语句优化器是不同意使用索引的。
2. 避免使用不兼容的数据类型。

        不兼容的数据类型代表着全表检索数据的类型转换。訪问将变为全表扫描
        select * from employee where last_name = 100;注last_name为varchar类型
3. 联接列
  对于有联接的列,即使最后的联接值为一个静态值,优化器是不会使用索引的。
        eg:select * from employee where first_name||”||last_name =’chen junjie’;
4.通配符(%)开头的like语句
        select * from employee where last_name like ‘%junjie%’;
5.索引字段上进行运算会使索引失效。
        尽量避免在WHERE子句中对字段进行函数或表达式操作,这将导致引擎放弃使用索引而进行全表扫描。
        eg:SELECT * FROM T1 WHERE F1/2=100 应改为: SELECT * FROM T1 WHERE F1=100*2
6.避免使用!=或<>、IN 。NOT IN等这种操作符.
        由于这会使系统无法使用索引,而仅仅能直接搜索表中的数据。

        eg:select * from employee where age != 30;
        优化器将无法通过索引来确定将要命中的行数,因此须要搜索该表的全部行。
        改成:select * from employee where age<30 or age>30;()
7.应尽量避免在 where 子句中使用 or 来连接条件,否则将导致引擎放弃使用索引而进行全表扫描,
        如:  select id from employee  where num=10 or num=20 
        能够这样查询:  select id from employee  where num=10 union all  select id from employee where num=20 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116465.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 软件工程实验报告:图书管理系统

    软件工程实验报告:图书管理系统一、课程设计的目的与要求课程设计目的软件工程课程设计是学习软件工程课程后所进行的实践环节,目的是培养学生用工程化的思想和标准文档化的思想进行软件开发。本次课程设计通过开发一个小型实用的软件系统,亲身体验软件生命周期中的各个环节,以加深对软件工程课程的深入理解、锻炼独立分析、解决问题的能力。课程设计要求2.1课程设计准备1)复习软件工程课程的主要内容,熟练掌握软件生命周期的理论以及各阶段的基本概念。2)明确可行性分析、需求分析、设计、测试等阶段的基本任务和基本方法。3)熟练运用规范化的描述

    2022年8月22日
    12
  • 医疗用户端app原型/问诊/挂号/开药/视频问诊/电子处方/预约/互联网医疗平台用户端/Axure原型/电话问诊/药品/就诊开药/远程医疗平台/线上问诊/线上看病/rp源文件/移动端医疗原型/门诊「建议收藏」

    医疗用户端app原型/问诊/挂号/开药/视频问诊/电子处方/预约/互联网医疗平台用户端/Axure原型/电话问诊/药品/就诊开药/远程医疗平台/线上问诊/线上看病/rp源文件/移动端医疗原型/门诊「建议收藏」医疗用户端app原型/问诊/挂号/开药/视频问诊/电子处方/预约/互联网医疗平台用户端/Axure原型/电话问诊/药品/就诊开药/远程医疗平台/线上问诊/线上看病/rp源文件/移动端医疗原型Axure原型演示地址:https://www.pmdaniu.com/storages/124091/e51ce895d0be36e758d8fbcebc67f6ef-93733/start.html#g=1&p=%E9%A6%96%E9%A1%B5【医药、医疗】互联网医疗平台(问诊+挂号+开药)-用户

    2022年6月16日
    33
  • JS设置定时器_js设置定时器

    JS设置定时器_js设置定时器JS定时器的一些特性和如何避免重复设置定时器概述和总结每个JS定时器产生时会被系统分配一个id,这个id是正整数,而且一个页面里面的定时器id不重复,我们能用一个变量接收这个id,但是如果重复执行一条接收创建语句,那么你只能接收到最新创建的定时器的id,之前创建的定时器的id会被覆盖,但是定时器数量在增加,这就会导致界面一些功能错乱,解决方法就是在重复按开始按钮时,如果已经有了一个定时器那么就不执行语句,我列出了错误代码和三种解决方法,可以解决定时器重复创建问题。ps:定时器id的配发是递增的,从1开

    2025年6月25日
    4
  • python调用matplotlib报错_pycharm没有matplotlib模块

    python调用matplotlib报错_pycharm没有matplotlib模块【Pycharm第二天】matplotlib安装不了?问题来了,一招搞定!

    2022年8月29日
    2
  • windows10切换快捷键_Word快捷键大全

    windows10切换快捷键_Word快捷键大全目录第一部分:Windows10系统快捷键复制、粘贴和其他常规快捷键Windows徽标键快捷键命令提示符快捷键对话框快捷键文件资源管理器快捷键虚拟桌面快捷键任务栏快捷键《设置》快捷键第二部分:Windows10应用的快捷键《MicrosoftEdge浏览器》快捷键《计算器》快捷键游戏栏快捷键《Groove》快捷键《地图》快捷键《电影…

    2022年9月29日
    6
  • 安全测评第一股——河南鑫安利选择契约锁电子签章

    安全测评第一股——河南鑫安利选择契约锁电子签章

    2021年6月18日
    110

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号