sqlserver索引优化及测试_mysql 索引优化

sqlserver索引优化及测试_mysql 索引优化1.1、查找缺失索引 SELECT A.USER_SEEKS 查找次数,A.USER_SCANS 扫描次数, ROUND(A.AVG_TOTAL_USER_COST,2) 减少的用户查询的平均成本,A

SQL Server高级进阶之索引优化查询

1.1、查找缺失索引

SELECT A.USER_SEEKS 查找次数,A.USER_SCANS 扫描次数,
    ROUND(A.AVG_TOTAL_USER_COST,2) 减少的用户查询的平均成本,A.AVG_USER_IMPACT 可能获得的平均百分比收益,
    ROUND((A.USER_SEEKS+A.USER_SCANS)*A.AVG_TOTAL_USER_COST*A.AVG_USER_IMPACT/100,2) 可能的改进优势,
    A.LAST_USER_SEEK 最近查找时间,A.LAST_USER_SCAN 最近扫描时间,C.[STATEMENT] 表名,
    "CREATE INDEX [IDX_"
        +CONVERT(VARCHAR,A.GROUP_HANDLE)+"_"+CONVERT(VARCHAR,C.INDEX_HANDLE)+"_"+REPLACE(REPLACE(REPLACE(C.[STATEMENT],"]",""),"[",""),".","")
        +"]"+" ON "+C.[STATEMENT]+ " ("
        +ISNULL(C.EQUALITY_COLUMNS,"")
        +CASE WHEN NOT C.EQUALITY_COLUMNS IS NULL AND NOT C.INEQUALITY_COLUMNS IS NULL THEN "," ELSE "" END
        +ISNULL(C.INEQUALITY_COLUMNS,"")
        +")"
        +ISNULL(" INCLUDE ("+C.INCLUDED_COLUMNS+")","") "创建语句"
FROM sys.dm_db_missing_index_group_stats A INNER JOIN sys.dm_db_missing_index_groups B ON A.GROUP_HANDLE=B.INDEX_GROUP_HANDLE
    INNER JOIN sys.dm_db_missing_index_details C ON B.INDEX_HANDLE=C.INDEX_HANDLE
WHERE C.DATABASE_ID=DB_ID()    --默认当前数据库,若指定数据库则使用DB_ID(["DB_NAME"])
ORDER BY ROUND(A.USER_SEEKS*A.AVG_TOTAL_USER_COST*A.AVG_USER_IMPACT/100,2) DESC

1.2、查找未使用索引

SELECT C.NAME 表名,B.INDEX_ID 索引ID,B.NAME 索引名,
    A.USER_SEEKS 搜索次数,A.USER_SCANS 扫描次数,A.USER_LOOKUPS 查找次数,
    A.USER_UPDATES 更新次数,E.TABLEROWS 表行数,
    "DROP INDEX "+QUOTENAME(B.NAME)+" ON "+QUOTENAME(D.NAME)+"."+QUOTENAME(OBJECT_NAME(A.OBJECT_ID)) "删除语句"
FROM sys.dm_db_index_usage_stats A INNER JOIN sys.indexes B ON A.INDEX_ID=B.INDEX_ID AND A.OBJECT_ID=B.OBJECT_ID
    INNER JOIN sys.objects C ON A.OBJECT_ID=C.OBJECT_ID
    INNER JOIN sys.schemas D ON C.schema_id=D.schema_id
    INNER JOIN 
        (
            SELECT INDEX_ID,OBJECT_ID,SUM(ROWS) TABLEROWS
            FROM sys.partitions
            GROUP BY INDEX_ID,OBJECT_ID
        ) E ON A.INDEX_ID=E.INDEX_ID AND A.OBJECT_ID=E.OBJECT_ID
WHERE OBJECTPROPERTY(A.OBJECT_ID,"IsUserTable")=1 AND A.DATABASE_ID=DB_ID()
    AND B.TYPE_DESC="NONCLUSTERED" AND B.IS_PRIMARY_KEY=0 AND B.IS_UNIQUE_CONSTRAINT=0
    --AND C.NAME="INVMB"    --根据实际修改表名
ORDER BY (A.USER_SEEKS+A.USER_SCANS+A.USER_LOOKUPS) ASC

当更新次数很大而搜索次数及扫描次数很小或为0时,说明该索引一直在更新但基本不被使用,因而也未对查询提供多少帮助,所以可以考虑删除。

1.3、查看索引使用情况

SELECT OBJECT_NAME(A.[OBJECT_ID]) 表名,B.INDEX_ID 索引ID,B.[NAME] 索引名称,B.[TYPE_DESC] 索引类型,
    A.USER_SEEKS+A.USER_SCANS+A.USER_LOOKUPS 读,A.USER_UPDATES 写,B.FILL_FACTOR 填充因子
FROM sys.dm_db_index_usage_stats A INNER JOIN sys.indexes B ON A.[OBJECT_ID]=B.[OBJECT_ID] AND A.INDEX_ID=B.INDEX_ID
WHERE OBJECTPROPERTY(A.[OBJECT_ID],"ISUSERTABLE")=1 
    AND A.DATABASE_ID=DB_ID()    --默认当前数据库,若指定数据库则使用DB_ID(["DB_NAME"])
ORDER BY OBJECT_NAME(A.[OBJECT_ID]),A.USER_UPDATES DESC,A.USER_SEEKS+A.USER_SCANS+A.USER_LOOKUPS DESC

 

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

(0)
上一篇 2023-04-23
下一篇 2023-04-23

相关推荐

  • 在centos7.x环境中SQL Server附加数据库[亲测有效]

    在centos7.x环境中SQL Server附加数据库[亲测有效]第一步,准备好windows与Linux之间文件传递的工具,下载并安装 https://winscp.net/eng/download.php 第二步,把本地的数据库文件拷贝一份,放到别的文件夹中,因

    2023-01-31
    257
  • oracle 修改字符集 为ZHS16GBK_oracle date

    oracle 修改字符集 为ZHS16GBK_oracle date1、主键与外键 主键:Primary 唯一标识 外键:Foreign 另一张表单的主键 2、约束 Oracle数据库共有5个约束:主键、外键、非空、唯一、条件 非空:这个列的值不能为空(not nu…

    2023-02-27
    172
  • 技术实践丨列存表并发更新时的锁等待问题原理「建议收藏」

    技术实践丨列存表并发更新时的锁等待问题原理「建议收藏」摘要:当开启transaction,执行updata的语句执行成功,不执行commit或rollback;再开启另一个窗口,执行upadate语句,会出现失败(报错:锁等待超时)的情况,但是如果对于…

    2023-04-13
    150
  • 用pip安装OpenCV

    用pip安装OpenCVOpenCV是一个基于BSD协议开源发行的跨平台计算机视觉库,它是专门用于图像处理和计算机视觉方面的开源库。随着计算机视觉的热度不断升温,OpenCV也变得越来越重要。本文将详细介绍如何使用pip来安装OpenCV。

    2024-08-20
    30
  • 用len函数评估Python代码的效率

    用len函数评估Python代码的效率Python作为一门高级编程语言,其代码简洁、易读、易懂的特点成为了众多开发者的首选。但是,在实际的应用过程中,我们也需要考虑代码的效率。本文将从多个方面探讨如何使用len函数评估Python代码的效率,为Python开发者提供一些有效的优化方案。

    2024-04-15
    78
  • Python命令行操作系统

    Python命令行操作系统随着科技不断进步,计算机和操作系统也在不断发展。如今,大多数人使用的都是图形用户界面(GUI)操作系统,如Windows、macOS和Linux等。但是,命令行操作系统同样重要,尤其是在一些特殊场景下。本文将介绍Python命令行操作系统,并从多个方面对其进行详细阐述。

    2024-03-31
    86
  • 使用Python创建文件夹

    使用Python创建文件夹创建文件夹是在编写Python程序时经常需要用到的操作之一。在Python中,我们可以使用多种方法来创建文件夹。无论我们使用哪种方法,都是基于操作系统提供的API来完成的。

    2024-06-14
    50
  • 如何安装Flask

    如何安装FlaskemFlask是一种轻量级的Web应用程序框架,它基于Python的Werkzeug工具包和Jinja2模板引擎构建。它易于学习和扩展,是一个受欢迎的选择,用于构建Web应用程序和API。/em

    2024-05-15
    64

发表回复

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