SQL Server SQL order by ID desc/asc加一个排序的字段解决查询慢实现方法

2022-11-12 09:49:32
内容摘要
这篇文章主要为大家详细介绍了SQL Server SQL order by ID desc/asc加一个排序的字段解决查询慢实现方法,具有一定的参考价值,可以用来参考一下。 对此感兴趣的朋友,看看idc笔
文章正文

这篇文章主要为大家详细介绍了SQL Server SQL order by ID desc/asc加一个排序的字段解决查询慢实现方法,具有一定的参考价值,可以用来参考一下。

对此感兴趣的朋友,看看idc笔记做的技术笔记!

解决方法就是在order by ID desc再加一个排序的字段,这样子可能会把速度提高很多。再加止排序的字段因查询而异了如表

代码如下:

 
CREATE TABLE [dbo].[CMPP_SendCentre] ( 
[id] [int] IDENTITY (1, 1) NOT NULL , 
[SendType] [varchar] (10) COLLATE Chinese_PRC_CI_AS NOT NULL , 
[SendDate] [datetime] NOT NULL , 
[Port] [varchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL , 
[Service_ID] [varchar] (20) COLLATE Chinese_PRC_CI_AS NOT NULL , 
[FeeType] [varchar] (2) COLLATE Chinese_PRC_CI_AS NOT NULL , 
[FeeCode] [varchar] (6) COLLATE Chinese_PRC_CI_AS NOT NULL , 
[Msg_Content] [varchar] (1024) COLLATE Chinese_PRC_CI_AS NOT NULL , 
[SendCount] [int] NOT NULL , 
[SucceedCount] [int] NOT NULL 
) ON [PRIMARY] 
GO 
CREATE TABLE [dbo].[CMPP_SendCentreMo] ( 
[id] [int] IDENTITY (1, 1) NOT NULL , 
[SendCentreID] [int] NOT NULL , 
[Mo] [varchar] (20) COLLATE Chinese_PRC_CI_AS NOT NULL , 
[Stat] [varchar] (10) COLLATE Chinese_PRC_CI_AS NULL 
) ON [PRIMARY] 
GO 
CMPP_SendCentreMo.SendCentreID 与CMPP_SendCentre.ID成外建关系 
于是建了一个视图

代码如下:

 
CREATE VIEW dbo.ViewCMPP_SendCentreMo 
AS 
SELECT 
dbo.CMPP_SendCentreMo.id, 
dbo.CMPP_SendCentreMo.SendCentreID, 
dbo.CMPP_SendCentreMo.Mo, 
dbo.CMPP_SendCentreMo.Stat, 
dbo.CMPP_SendCentre.SendType, 
dbo.CMPP_SendCentre.SendDate, 
dbo.CMPP_SendCentre.Port, 
dbo.CMPP_SendCentre.Service_ID, 
case dbo.CMPP_SendCentre.FeeType when '01' then '免费' when '02' then '点播' else '包月' end as FeeType, 
cast(dbo.CMPP_SendCentre.FeeCode as smallint) as FeeCode, 
dbo.CMPP_SendCentre.Msg_Content 
FROM dbo.CMPP_SendCentre INNER JOIN 
dbo.CMPP_SendCentreMo ON 
dbo.CMPP_SendCentre.id = dbo.CMPP_SendCentreMo.SendCentreID 
一开始的查询语句为

代码如下:

 
select top 6*from [ViewCMPP_SendCentreMo] 
where SendType = '扣费' 
order by id desc 
发现非常的慢经过了解,原因是order by id desc/asc的查询是一行一行的找数据,所以非常的慢于是改成了

代码如下:

 
select top 6*from [ViewCMPP_SendCentreMo] 
where SendType = '扣费' 
order by SendCentreID desc, id desc 
查询就非常的快了

注:关于SQL Server SQL order by ID desc/asc加一个排序的字段解决查询慢实现方法的内容就先介绍到这里,更多相关文章的可以留意

代码注释

作者:喵哥笔记

IDC笔记

学的不仅是技术,更是梦想!