SQL order by ID desc/asc加一个排序的字段解决查询慢问题
2012-12-16 00:00
956 查看
解决方法就是在order by ID desc再加一个排序的字段,这样子可能会把速度提高很多。再加止排序的字段因查询而异了
如表
于是建了一个视图
一开始的查询语句为
发现非常的慢
经过了解,原因是order by id desc/asc的查询是一行一行的找数据,所以非常的慢
于是改成了
查询就非常的快了
如表
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
查询就非常的快了
相关文章推荐
- 解决 联表查询 group by 之后 order by desc 不支持排序问题
- 在使用Hibernate时,因为一个查询需要更多的表连接而要使用SQL来解决性能问题。然而返回的结果集中包含了没有映射的Entity类中的表字段,在这个SQL中还有使用如何将层次关系的父子结点显示为横行
- 解决Mysql数据库实现多表联合查询及按照其中一个字段进行排序问题
- mysql5.7中的一个update order by排名问题解决办法(一条sql搞定排名)
- mysql5.7基础 select...order by...asc 按照一个字段进行升序排序
- Hibernate使用原生SQL多表查询时字段名相同导致查询数据覆盖问题解决办法
- sql server row_number() over(partition by grower_pk order by a.pk_id desc)
- LINQ找出重复和不重复的元素及linq OrderBy 方法 两个字段同时排序有关问题
- oracle 和 db2 排序 order by desc/asc nulls last/nulss first 的用法将空值放到最后最前
- mysql5.7基础 select...order by...desc 按照一个字段进行降序排列
- 解决视图(SQL查询语句)唯一ID问题
- 执行SQL语句时出现问题操作必须使用一个可更新的查询错误的解决方法
- 分组查询 group by having 排序 order by asc(升序)或desc(降序)
- 关于sql语句中top + order by语句出现多提取问题的解决[cherryt笔记]
- 查询一个表中所有id字段在另一个表中对应值的SQL语句怎么写?
- 关于SQL查询的字符串类型字段的排序问题
- sql order by 查询问题
- 解决一个union多表排序查询问题
- Sql order by 数据排序 优先级问题