| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1910 人关注过本帖
标题:数据库的筛选问题(VB.net)
只看楼主 加入收藏
wind805
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2007-5-21
收藏
 问题点数:0 回复次数:12 
数据库的筛选问题(VB.net)
数据库Db有个Table
里面有如下内容:
ID S_Number S_Name
1 1 lakjlf
2 2 hhhlk
3 3 sdhfl
......
......
99 99 dkhflsk
100 100 llkdflkh

我要选择S_Number从90到100那段,并且读取内容的时候要从90开始读取,
要用什么语句,不能用ID列来选,因为ID是不固定的.
如果用 select top 10 * from table order by S_Number 的话,选择到的是1-10,
用 select top 10 * from table order by S_Number desc 的话,选择的是100-90,反了顺序,
该怎么选???

感谢frxyrx,不过忘了说了,S_Number会不断增加,所以不一定就是90-100,我意思是要选择S_Number
最大的那10个,然后从小到大读取数据。

[此贴子已经被作者于2007-5-21 14:37:27编辑过]

搜索更多相关主题的帖子: 数据库 Number 筛选 order table 
2007-05-21 13:34
frxyrx
Rank: 1
等 级:新手上路
威 望:1
帖 子:66
专家分:0
注 册:2006-11-2
收藏
得分:0 
用BETWEEN...AND...做查询啊

select * from table where S_Number between 90 and 100
2007-05-21 14:18
wind805
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2007-5-21
收藏
得分:0 
感谢frxyrx,不过忘了说了,S_Number会不断增加,所以不一定就是90-100,我意思是要选择S_Number
最大的那10个,然后从小到大读取数据。
2007-05-21 15:12
frxyrx
Rank: 1
等 级:新手上路
威 望:1
帖 子:66
专家分:0
注 册:2006-11-2
收藏
得分:0 

那就写个嵌套查询

select * from table
where S_Number in
( select top 10 * from table order by S_Number desc )
order by S_Number;

2007-05-21 15:58
bygg
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:乖乖的心中
等 级:版主
威 望:241
帖 子:13555
专家分:3076
注 册:2006-10-23
收藏
得分:0 
create PROCEDURE selDt1
AS
declare @rowid int
begin
select @rowid = (count(*)-10) from tablename
select identity(int,1,1) rownum,* into #tmp from tablename
select id,ta,tb from #tmp where rownum > @rowid
drop table #tmp
end

飘过~~
2007-05-21 16:04
wind805
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2007-5-21
收藏
得分:0 
错误信息:所编写的一个子查询可在不在主查询的 FROM 子句中使用的 EXISTS 保留字的情况下返回多个字段。 修改子查询的 SELECT 语句以只要求返回一个字段。
2007-05-21 16:17
bygg
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:乖乖的心中
等 级:版主
威 望:241
帖 子:13555
专家分:3076
注 册:2006-10-23
收藏
得分:0 
有错????晕..我都用了几次了..

飘过~~
2007-05-21 16:42
wind805
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2007-5-21
收藏
得分:0 
不好意思,错误信息是回4楼的,5楼的还没看懂,试验中。
2007-05-21 16:44
wind805
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2007-5-21
收藏
得分:0 


select * from table where S_Number in( select top 10 S_Number from table order by S_Number desc )order by S_Number desc

OK了,

4楼的方法对了,不过细节没搞好,对于我们新人来说还是有一定难度,
5楼的没看懂,不理了。
2007-05-23 00:10
huqianli
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2007-5-25
收藏
得分:0 
select ID,S_Number,S_Name from ( select ROWNUM row_id,ID, S_Number,S_Name from Table where row_id between 90 and 100) 我认为这样更好万一题目要你从30到40你也从大到小排列吗?这样只要更改90 和100的数字就行了。
2007-05-25 16:08
快速回复:数据库的筛选问题(VB.net)
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.012452 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved