您好,欢迎访问一九零五行业门户网

数据库取前几条记录的语句

数据库取前几条记录的语句 1. oracle www.2cto.com select * from table1 where rownum=n 2. informix select first n * from table1 where 1=1 3. db2 select * row_number() over(order by col1 desc) as rownum where rownum=n 或者 select column from t
数据库取前几条记录的语句
1. oracle     www.2cto.com  
select * from table1 where rownum
2. informix 
select first n * from table1 where 1=1 
3. db2 
select * row_number() over(order by col1 desc) as rownum where rownum
或者 
select column from table where 1=1 fetch first n rows only 
4. sql server 
select top n * from table1 where 1=1 
or 
set rowcount n select * from table1 where 1=1 set rowcount n1 
5. sybase 
set rowcount n select * from table1 where 1=1 set rowcount n1 
6. mysql 
select * from table1 where 1=1 limit n 
7. foxpro 
select * top n from table order by column 
8. access 
select top n * from table1 where 1=1
1. oracle数据库
select * from tablename where rownum
2. infomix数据库
select first n * from tablename
3. db2数据库
select *
from (select * row_number() over({order by col1 desc}) as rownum from tablename)
where rownum
或者
select column from tablename fetch first n rows only
4. sql server数据库
select top n * from tablename
5. sybase数据库
set rowcount n
go
select * from tablename
6. mysql数据库
select * from tablename limit n
7. foxpro数据库
select * top n from tablename order by column
top关键字:
1、首先引用一位网友出错的例子,sql=select top 30 * from data where title='&title1&' order by id desc
分析出错原因:sql语句里同时存在where和top语句的时候,并且where条件列不是合适的索引,程序执行的是全表扫描,首先是查找符合where条件的记录,而这里的top限制形同虚设。如果全表是百万级别以上的数据表,那么就这么一个简单的判断,就有可能拖垮数据库。
2、解决办法就是去掉where条件筛选语句,如果你希望使用selcet top语句,并且还要附带where条件,那么条件中的列就得是合适的索引,如聚集索引、复合索引里的主列等,同时,where条件里也要尽量避开使用函数,or,判断null等会引起全部扫描的语句。这一点要记住,不然执行的是全表扫描。
3、如何选出第n条到第2n条记录呢。这样的sql语句就可以了:
“select top n * from table_name where id not in (select top n id from table_name order by id desc)
4、对top基本理解下(top 和 set rowcount)
select 语句中的top子句限制单个查询返回的行数,而set rowcount限制所有后续查询影响的行数。在很多编程任务中这些命令提供了高效率。
set rowcount在select,insert,update or delete语句中设置可以被影响的最大行数。这些设置在命令执行时马上生效并且只影响当前的会话。为了移除这个限制执行set rowcount 0。一些实际的任务用top or set rowcount比用标准的sql命令对编程是更有效率的。让我们在几个例子中证明:
在几乎所有的数据库中最流行的一个查询是请求一个列表中的前n项。在 pubs数据库案例中,我们可以查找销售最好cd的前五项。比较用top,set rowcount和使用ansi sql的三种方案。
(1)select title,ytd_salesfrom titlesa where (select count(*)from titlesb where b.ytd_sales>a.ytd_sales)
这个纯ansi sql方案执行一个效率可能很低的关联子查询,特别的在这个例子中,在ytd_sales上没有索引支持。另外,这个纯的标准sql命令没有过滤掉在ytd_sales的空值,也没有区别多个cd间有关联的情况。
(2)set rowcount 5 select title, ytd_salesfrom titlesorder by ytd_sales descset rowcount 0
(3)select top 5 title, ytd_salesfrom titlesorder by ytd_sales desc
第二个方案使用set rowcount来停止select查询,而第三个方案是当它找到前五行时用top n来停止。在这种情况下,在获得结果之前我们也要有一个order by子句强制对整个表进行排序。两个查询的查询计划实际上是一样的。然而,top优于set rowcount的关键点是set必须处理order by子句所需的工作表,而top 不用。
总结:在一个大表上,我们可以为表上创建一个索引以避免排序,查询将使用该索引找到前5行并停止。
rownum伪列:
1、使用select语句返回的结果集,希望按特定条件查询前n条记录,可以使用伪列rownum。rownum是对结果集加一个伪列,先查到结果集后再加上一个列,是符合条件结果的序列号;从1开始排起,只能用 = !=这些比较符合。
rownum对于等于某值的查询条件,比如查询第一条记录,可以使用rownum=1作为条件;但是如果查询第二条记录写rownum=2则查询不到数据,rownum的=判断只对于1有效;
2、同理,查询大于某值的查询条件,rownum>n(n>1的自然数)这种条件不成立;那如何查询第一行以后的记录呢?
solution:用子查询解决,但是必须为rownum设置别名,select * from (select rownum no ,id,name from table1) where no >1;
3、rownum对于小于某值的查询是可以的,select * from table1 where rownum
4、rownum和排序
oracle中rownum是在取数据时产生的序号,想对指定排序的数据指定rownum行数据就要做处理了:
select rownum,id,name from table1 order by name,查询结果按name排序,但是rownum不是按1、2、3...排列,而是按记录插入时的顺序给记录排号;
solution:使用子查询,select rownum ,id,name from(select * from table1 order by name)
其它类似信息

推荐信息