zoukankan      html  css  js  c++  java
  • sql查询like和charindex和substring比较性能测试

    300万条记录 like 和 charindex 函数以及substring函数性能比较:

    环境:sql2005

    数据量:300万

    查询结果数据量:2849999

    机器环境

    P4 3.0双核 2G内存

    1. 执行语句

    表结构:

    USE [Test]
    GO
    /****** 对象:  Table [dbo].[TabTest]    脚本日期: 03/22/2011 09:46:20 ******/
    SET ANSI_NULLS ON
    GO
    SET QUOTED_IDENTIFIER ON
    GO
    CREATE TABLE [dbo].[TabTest](
    	[id] [int] IDENTITY(1,1) NOT NULL,
    	[ypmc] [nvarchar](50) NULL,
    	[ypdm] [nvarchar](50) NULL,
    	[cdmc] [nvarchar](50) NULL,
    	[cddm] [nvarchar](50) NULL,
    	[gg] [nvarchar](50) NULL,
    	[list] [nvarchar](50) NULL,
    	[doc1] [nvarchar](50) NULL,
    	[ywuserid] [int] NULL,
    	[flag] [tinyint] NULL,
    	[flagstr] [nchar](10) NULL
    ) ON [PRIMARY]
    
    /*仅list字段建聚集索引*/
    select * from TabTest where list like '%a%' and ywuserid=10215
    select * from TabTest where charindex('a',list)>0 and ywuserid=10215
    select * from TabTest where substring(list ,1,1) = 'a' and ywuserid=10215
    /*仅list字段建非聚集索引*/
    select * from TabTest where list like '%a%' and ywuserid=10215
    select * from TabTest where charindex('a',list)>0 and ywuserid=10215
    select * from TabTest where substring(list ,1,1) = 'a' and ywuserid=10215
    /*list字段不建索引*/
    select * from TabTest where list like '%a%' and ywuserid=10215
    select * from TabTest where charindex('a',list)>0 and ywuserid=10215
    select * from TabTest where substring(list ,1,1) = 'a' and ywuserid=10215
    /*查询字段和list建索引*/
    select * from TabTest where list like '%a%' and ywuserid=10215
    select * from TabTest where charindex('a',list)>0 and ywuserid=10215
    select * from TabTest where substring(list ,1,1) = 'a' and ywuserid=10215
    /*全部字段和list建索引*/
    select * from TabTest where list like '%a%' and ywuserid=10215
    select * from TabTest where charindex('a',list)>0 and ywuserid=10215
    select * from TabTest where substring(list ,1,1) = 'a' and ywuserid=10215
    

    仅list字段建聚集索引性能分析:

    仅list字段建非聚集索引性能分析:

    字段不建索引性能分析:

    看到上面结果后:

    试了一下如下查询:

    /*查询300万条*/
    /*仅list字段建聚集索引*/
    select * from TabTest where list like '%a%' 
    select * from TabTest where charindex('a',list)>0 
    select * from TabTest where substring(list ,1,1) = 'a' 
    /*仅list字段建非聚集索引*/
    select * from TabTest where list like '%a%' 
    select * from TabTest where charindex('a',list)>0 
    select * from TabTest where substring(list ,1,1) = 'a' 
    /*list字段不建索引*/
    select * from TabTest where list like '%a%'
    select * from TabTest where charindex('a',list)>0 
    select * from TabTest where substring(list ,1,1) = 'a' 
    

    /*list字段不建索引*/

    /*仅list字段建非聚集索引*/

    /*仅list字段建聚集索引*/


    自己看看性能比较结果吧!

  • 相关阅读:
    数学 之 hdu 4722
    DP + math 之 Codeforces 126D
    计算几何 之 hdu 1077 poj 1981 O(n^2logn)
    计算几何 之 hdu 1077 poj 1981 O(n^3)
    字典树 之 hdu 1800
    字典树 之 poj 1056
    字典树 之 hdu 4099
    字典树 之 hdu 1247
    解决java.sql.SQLException: Value '0000-00-00' can not be represented as java.sql.Date
    显示Mac壁纸所在路径以及接下来的事情你懂得
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/1991102.html
Copyright © 2011-2022 走看看