奇怪的SQLserver执行

今天工作遇到,下面这段执行超慢,几乎不出来,在旧服务器上运行是可以的,一样代码,很快,在新虚拟服务器上,超慢。

     select * from
        (
            select RowNum=row_number() over(order by AutoId desc),StartTime,cast(testtime/1000.00 as decimal(10,2)) as testtime,AutoId
            from dbo.FTMaster M
             WITH(NOLock) Where StartTime >=‘2014-01-01 00:00:00.000‘ and StartTime <‘2014-12-31 23:00:00.000‘ and ModelIc=‘XXX‘ and Result=0 and TestType=3
            and exists
            (
                select AutoId from
                (
                    select Min(BB.autoid) AutoID             from
                     (Select Max(StartTime) as starttime,SN From dbo.FTMaster WITH(NOLock)              Where StartTime >=‘2014-01-01 00:00:00.000‘ and StartTime <‘2014-12-31 23:00:00.000‘ and ModelIc=‘XXX‘ and TestType=3 group by Sn) as AA
                     inner join             (Select AutoID,SN,StartTime From dbo.FTMaster WITH(NOLock)                Where StartTime >=‘2014-01-01 00:00:00.000‘ and StartTime <‘2014-12-31 23:00:00.000‘ and ModelIc=‘XXX‘ and TestType=3 ) As BB              on AA.SN=BB.SN And AA.StartTime=BB.StartTime
                    group by BB.SN
                ) t where t.AutoId=M.AutoId
            )
        )
        as MasterTable
        WHERE RowNum between (1 - 1) * 12430 + 1 and 1 * 12430

执行里面的又很快, 为什么呢。

       select RowNum=row_number() over(order by AutoId desc),StartTime,cast(testtime/1000.00 as decimal(10,2)) as testtime,AutoId
            from dbo.FTMaster M
             WITH(NOLock) Where StartTime >=‘2014-01-01 00:00:00.000‘ and StartTime <‘2014-12-31 23:00:00.000‘ and ModelIc=‘XXX‘ and Result=0 and TestType=3
            and exists
            (
                select AutoId from
                (
                    select Min(BB.autoid) AutoID
            from
                     (Select Max(StartTime) as starttime,SN From dbo.FTMaster WITH(NOLock)
             Where StartTime >=‘2014-01-01 00:00:00.000‘ and StartTime <‘2014-12-31 23:00:00.000‘ and ModelIc=‘XXX‘ and TestType=3 group by Sn) as AA
                     inner join
            (Select AutoID,SN,StartTime From dbo.FTMaster WITH(NOLock)   
             Where StartTime >=‘2014-01-01 00:00:00.000‘ and StartTime <‘2014-12-31 23:00:00.000‘ and ModelIc=‘XXX‘ and TestType=3 ) As BB
             on AA.SN=BB.SN And AA.StartTime=BB.StartTime
                    group by BB.SN
                ) t where t.AutoId=M.AutoId
            )    
时间: 2024-12-28 10:42:45

奇怪的SQLserver执行的相关文章

解决&#160;SqlServer执行脚本,文件过大,内存溢出问题

原文:解决 SqlServer执行脚本,文件过大,内存溢出问题 执行.sql脚本文件,如果文件较大时,执行会出现内存溢出问题,可用命令替代 cmd 中输入 osql -S 127.0.0.1,8433 -U sa -P sa -i d:\sql.sql ,-S 服务器名 -U 用户名 -P 密码 -i 文件地址,等待执行完毕即可 以上在sql2008R2下执行通过 如果数据库是 sql2008的 请将 osql 修改成为 sqlcmd 即可

查询SQLSERVER执行过的SQL记录

原文:查询SQLSERVER执行过的SQL记录 有的时候,需要知道SQLSERVER执行了什么语句,可以用下面的方法: SELECT TOP 1000 --创建时间 QS.creation_time, --查询语句 SUBSTRING(ST.text,(QS.statement_start_offset/2)+1, ((CASE QS.statement_end_offset WHEN -1 THEN DATALENGTH(st.text) ELSE QS.statement_end_offse

SQLServer执行计划生成方式

说一点关于SQLServer 执行计划相关的东西吧,首先我不是DBA,这几年也做了一些关于SQL优化的东西,有一点自己理解的东西,说的不一定正确. 首先从应用程序传过来的T-SQL语句和存储过程的差异就是传过来的语句SQLServer会进行一次编译,而存储过程则是编译好的,执行时无需再次编译,等于就是一次编译多次执行,而传过来的SQL语句如果不是参数化查询的话不同的条件会生成不同的执行计划,举个栗子:SELECT * FROM dbo.Employee  WHERE ID = 1和 SELECT

查询SQLSERVER执行过的SQL记录(历史查询记录)(转)

原文链接:https://www.cnblogs.com/icycore/p/10493237.html 有的时候,需要知道近段时间SQLSERVER执行了什么语句,可以用下面的方法: SELECT TOP 1000 QS.creation_time, SUBSTRING(ST.text, (QS.statement_start_offset / 2) + 1, ((CASE QS.statement_end_offset WHEN - 1 THEN DATALENGTH(st.text) EL

SQLServer执行命令出现“目录无效的提示”

异常处理汇总-数据库系列  http://www.cnblogs.com/dunitian/p/4522990.html 一般都是清理垃圾清理过头了,把不该删的目录删了 网上说法: 问题描述: 1.sqlserver 打开表提示:目录名称无效 2.在执行sql语句时提示:在执行批处理时出现错误.错误消息为: 目录名无效 3.所有的数据库都存在1跟2的问题 问题分析: 1.操作系统重装或进行过系统镜像还原,导致temp目录下的文件夹丢失. 2.杀毒软件误删. 3.被人为或其他软件删除. 解决方案:

使用SQLCMD在SQLServer执行多个脚本 转载

出处不明 概述: 作为DBA,经常要用开发人员提供的SQL脚本来更新正式数据库,但是一个比较合理的开发流程,当提交脚本给DBA执行的时候,可能已经有几百个sql文件,并且有执行顺序,如我现在工作的公司,十几个客户,每个客户一个库,但是数据库结构.存储过程.视图等都是一模一样,每次执行脚本(以下称为升级),如果有一百个脚本,那么就要按顺序执行过千次,这种工作量可不是一个人能承受得了的. 解决方法: 应对这种情况有以下几种方法: 1.  购买第三方软件(一般估计很少人买) 2.  自己编程一个小软件

使用SQLCMD在SQLServer执行多个脚本

概述: 作为DBA,经常要用开发人员提供的SQL脚本来更新正式数据库,但是一个比较合理的开发流程,当提交脚本给DBA执行的时候,可能已经有几百个sql文件,并且有执行顺序,如我现在工作的公司,十几个客户,每个客户一个库,但是数据库结构.存储过程.视图等都是一模一样,每次执行脚本(以下称为升级),如果有一百个脚本,那么就要按顺序执行过千次,这种工作量可不是一个人能承受得了的. 解决方法: 应对这种情况有以下几种方法: 1.  购买第三方软件(一般估计很少人买) 2.  自己编程一个小软件来执行,但

(转)使用SQLCMD在SQLServer执行多个脚本

概述: 作为DBA,经常要用开发人员提供的SQL脚本来更新正式数据库,但是一个比较合理的开发流程,当提交脚本给DBA执行的时候,可能已经有几百个sql文件,并且有执行顺序,如我现在工作的公司,十几个客户,每个客户一个库,但是数据库结构.存储过程.视图等都是一模一样,每次执行脚本(以下称为升级),如果有一百个脚本,那么就要按顺序执行过千次,这种工作量可不是一个人能承受得了的. 解决方法: 应对这种情况有以下几种方法: 1.  购买第三方软件(一般估计很少人买) 2.  自己编程一个小软件来执行,但

sqlserver 执行正则表达式,调用c# 函数、代码

--1.新建SqlServerExt项目,编写 C# 方法生成 SqlServerExt.dll 文件 using System; using System.Data; using System.Data.SqlClient; using System.Data.SqlTypes; using System.Text.RegularExpressions; using Microsoft.SqlServer.Server; namespace Ext { public static partia