时间:2021-07-01 10:21:17 帮助过:42人阅读
一、oracle、mysq、sqlserver取结果中几行记录的 区别 http://www.w3school.com.cn/sql/sql_top.asp 原始的表 (用在例子中的): Persons 表: Id LastName FirstName Address City 1 Adams John Oxford Street London 2 Bush George Fifth Avenue New York 3
一、oracle、mysq、sqlserver取结果中几行记录的区别
http://www.w3school.com.cn/sql/sql_top.asp
Persons 表:
Id | LastName | FirstName | Address | City |
---|---|---|---|---|
1 | Adams | John | Oxford Street | London |
2 | Bush | George | Fifth Avenue | New York |
3 | Carter | Thomas | Changan Street | Beijing |
4 | Obama | Barack | Pennsylvania Avenue | Washington |
TOP 子句用于规定要返回的记录的数目。
对于拥有数千条记录的大型表来说,TOP 子句是非常有用的。
注释:并非所有的数据库系统都支持 TOP 子句。
SELECT TOP number|percent column_name(s)FROM table_nameSQL TOP 实例
现在,我们希望从上面的 "Persons" 表中选取头两条记录。
我们可以使用下面的 SELECT 语句:
SELECTTOP 2
* FROM Persons结果:
Id | LastName | FirstName | Address | City |
---|---|---|---|---|
1 | Adams | John | Oxford Street | London |
2 | Bush | George | Fifth Avenue | New York |
现在,我们希望从上面的 "Persons" 表中选取 50% 的记录。
我们可以使用下面的 SELECT 语句:
SELECT TOP 50 PERCENT
* FROM Persons
结果:
Id | LastName | FirstName | Address | City |
---|---|---|---|---|
1 | Adams | John | Oxford Street | London |
2 | Bush | George | Fifth Avenue | New York |
select top n * from (select top m * from tablename order by columnname) a order by columnname desc
这个是用一个 sqlserver中 top比order by 后执行 的原理。
第二种方法:
/*以下示例将返回行号为 50 到 60(含)的行,并以 OrderDate 排序。*/ select * from( select row_number() over (order by orgid) as rownum from org_info ) as wo where wo.rownumber between 50 and 60
SELECT column_name(s)FROM table_nameLIMIT number
例子
SELECT *FROM Persons LIMIT 5
SELECT column_name(s)FROM table_nameWHERE ROWNUM <= number
SELECT * FROM (SELECT ROWNUM RM, UI.* FROM USER_INFO UI WHERE ROWNUM < 10) WHERE RM > 5;
这个中也可以用 继续进行限制,如 最后一个where 条件中变为:RM>5 AND RM<8。那结果就是 取 第6到7条记录了!
SELECT *FROM PersonsWHERE ROWNUM <= 5
注意
1、sqlserver 中SQL的执行顺序。
注意:这里的TOP 在 order by 的后面执行。意思是:sqlserver先进行排序再取top的数据。
2、oracle 中 order by 也是比 rownum先执行。
二、IF ELSE 区别:
mysql和oracle的区别:
1)、注意elseif区别:
在mysql中:
IF search_condition THEN statement_list
[ELSEIF search_condition THEN statement_list] ...
[ELSE statement_list]
END IF
IF 条件1 THEN ...如果条件1为真,则执行这里的语句... ELSIF 条件2 THEN ...如果条件1为假,但是条件2为真,则执行这里的语句... ELSE ...如果条件1和条件2都为假,则执行这里的语句... END IF; |