sql 2008 已经建立了时间字段的聚集索引,但是 过滤后的结果,记录排列都是乱的,怎么回事?

使用order是可以,但是正常排序后的表在执行过滤应该也是按顺序的啊!... 使用order是可以,但是正常排序后的表 在执行过滤应该也是按顺序的啊! 展开
 我来答
yyltty
2012-03-26 · 超过48用户采纳过TA的回答
知道小有建树答主
回答量:128
采纳率:0%
帮助的人:125万
展开全部
理解上的错误,数据库正常记录集是按插入表顺序,使用ORDER BY 后可以查询排序,但重新查询后顺序并不是按你上一条命令排列的,你需要将ORDER BY 填写到条件后面,对查询结果排序才可以。 (select * from 表 where nl='18' and dt>'2012-03-11 02:00:00' and dt<'2012-03-21 02:00:00 order by dt')
追问
之前sql2000里面只要给表加了索引,过滤出来的数据就还是正常的顺序。
是不是2008里面执行查询时相当于新建了一个临时表?
另外还有一点
我使用
select * from 表
查出来的没问题,只要一加上where,顺序就乱了。

在线等 谢谢!
百度网友c9b73c043
2012-04-05 · TA获得超过382个赞
知道小有建树答主
回答量:226
采纳率:0%
帮助的人:131万
展开全部
order by 吧 再说 还没看出你的日期字段排序是错的啊 不是正常的日期升序排列吗
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
hzchun
2012-03-27 · 超过68用户采纳过TA的回答
知道小有建树答主
回答量:243
采纳率:0%
帮助的人:204万
展开全部
给用orderby ,你加索引也只是查询和默认的排序,但你查询里面有where 了,就给用order by 排序一下
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式