怎么查询sqlite里面第三行的数据
展开全部
也不知道你要使用的是哪种数据库。那就给你介绍下在ms sqlserver和oracle中的查询方法。
在ms sqlserver(也就是微软的数据库,如sql server2005)中可以使用top来查询前三行。在ms sqlserver中无论你是否将查询到得结果按照每一个字段(如学生的年龄)进行了降序或升序(在使用order by的时候默认为升序)排序,都可以查询到你想要的最大的前三行或最小的前三行。在ms sqlserver中查询前多少行是比较简单的。
但是,在oracle中并没有top,那么我们是不是就不能查询到前三行了呢?当然不是!在oracle中有一个伪列(如果你对伪列不太清楚请百度一下),我们可以再查询的语句后面添加一个条件 where rownum<=3。但是这种方法是适用于没有使用orderby的查询语句,一旦查询语句中使用了order by,那么rownum也会随之放生变化;如果想要查询出使用了order by的结果中的前三行,就需要用到子查询。例如:我们要查询出scott.emp中工资最高的员工的姓名和工资,就需要分成一下几步:
第一步:先查询出scott.emp中员工的姓名和工资,然后按照工资降序排列,并且将查询到的结果看做是一张新表
第二步:从新表中查询第三行数据;
select * from (select enmae,sal from emp order by sal desc) where rownum = 3。
在ms sqlserver(也就是微软的数据库,如sql server2005)中可以使用top来查询前三行。在ms sqlserver中无论你是否将查询到得结果按照每一个字段(如学生的年龄)进行了降序或升序(在使用order by的时候默认为升序)排序,都可以查询到你想要的最大的前三行或最小的前三行。在ms sqlserver中查询前多少行是比较简单的。
但是,在oracle中并没有top,那么我们是不是就不能查询到前三行了呢?当然不是!在oracle中有一个伪列(如果你对伪列不太清楚请百度一下),我们可以再查询的语句后面添加一个条件 where rownum<=3。但是这种方法是适用于没有使用orderby的查询语句,一旦查询语句中使用了order by,那么rownum也会随之放生变化;如果想要查询出使用了order by的结果中的前三行,就需要用到子查询。例如:我们要查询出scott.emp中工资最高的员工的姓名和工资,就需要分成一下几步:
第一步:先查询出scott.emp中员工的姓名和工资,然后按照工资降序排列,并且将查询到的结果看做是一张新表
第二步:从新表中查询第三行数据;
select * from (select enmae,sal from emp order by sal desc) where rownum = 3。
2016-04-27
展开全部
limit 函数
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |