十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
oracle,
海陵网站建设公司创新互联建站,海陵网站设计制作,有大型网站制作公司丰富经验。已为海陵上千提供企业网站建设服务。企业网站搭建\外贸网站建设要多少钱,请找那个售后服务好的海陵做网站的公司定做!
sql
server
和mysql的分页sql语句如下:oracle:方法一:select
*
from(select
a.*,
rownum
rn
from
(select
*
from
table_name)
a
where
rownum
=
40)where
rn
=
21;方法二:select
*
from(select
a.*,
rownum
rn
from
(select
*
from
table_name)
a)where
rn
between
21
and
40
公认第二种方法效率没有第一种高。原因是第二种要把子查询执行完,而第一种方法子查询执行到rownum=40后就结束了。mysql:
select
*
from
table_name
limit
10,
20
表示从第11条数据开始取20条数据返回,limit后的2个参数含义为:起点和步长,即从那条数据开始,取多少条数据,再如取前20条数据:select
*
from
table_name
limit
0,
20
sql
server2000:
select
top
@pagesize
*
from
table_name
where
id
not
in
(select
top
@pagesize*(@page-1)
id
from
table_name
order
by
id)
order
by
id
Oracle分页查询格式:\x0d\x0a以下是代码片段:\x0d\x0aSELECT * FROM\x0d\x0a(\x0d\x0aSELECT A.*, ROWNUM RN\x0d\x0aFROM (SELECT * FROM TABLE_NAME) A\x0d\x0aWHERE ROWNUM = 21\x0d\x0a \x0d\x0amysql\x0d\x0amysql SELECT * FROM table LIMIT 5,10; // 检索记录行 6-15 ,注意,10为偏移量\x0d\x0a//为了检索从某一个偏移量到记录集的结束所有的记录行,可以指定第二个参数为 -1:\x0d\x0amysql SELECT * FROM table LIMIT 95,-1; // 检索记录行 96-last.\x0d\x0a//如果只给定一个参数,它表示返回最大的记录行数目:\x0d\x0amysql SELECT * FROM table LIMIT 5; //检索前 5 个记录行 //也就是说,LIMIT n 等价于 LIMIT 0,n。
在Oracle中有一个方法rownum用来查询第一行到第n行的内容,但没有一个合适的方法若查询第x行到第y行的内容,而在实际应用中却经常需要查询第x行到第y行的内容,这时我们就需要使用rownum和子表查询等内容来进行查询,因为这一块内容属于Oracle总的常用部分所以专门在此介绍。
在Oralce中有一个伪列rownum,其在创建表的时候就存在了却不显示,若要使用这个列可以直接调用即可,也可以对这个列添加别名来调用。
rownum只能用于显示小于某行的数据即第一行开始到你要查询到的那一行为止的数据。
在Oracle把查询第几行到第几行的操作称为分页,其具体操作是通过子查询等操作完成。
select 列名 from (select 表名.*,rownum rn from 表名)表名 where rn操作;
思考如下:
1.选择所有内容
select * from emp;
2.显示rownum
select e.*,rownum rn from(select * from emp)e;
这一步可以精简为下面形式,但某些情况只能用上面那种
select emp.*,rownum rn from emp;
3.查询
select * from(select e.*,rownum rn from (select * from emp)e);
4.其他变化
在某些时候我们需要先对表的内容进行排序,随后查询第x行到第y行的内容,这个时候有一个需要注意的点是rownum是在表产生的时候产生的伪列,所以使用排序会连着rownum的值进行排序,从而达不到想要的效果。
为了解决上述这个问题,我们需要使用子表查询即先排好序,再在新表之中显示rownum来规避这个问题。
考虑到排序的问题,所以在上方第二步的时候使用第一种方法即select e.*,rownum rn from(select * from emp)e;,在内表select * from emp中进行排序可以完成在乱序中找到第x行到第y行的效果。