在Oracle怎样查询表中的top10条记录
下面是关于rownum的介绍 ================================ Rownum和row_number() over()的使用 ROWNUM是Oracle从8开始提供的一个伪列,是把SQL出来的结果进行编号,始终从1开始,常见的用途就是用来分页输出. 比如SELECT *FROM torderdetail a WHERE ROWNUM = 10 这条语句就是输出前10条纪录,在这里用途上类似于sql sever的top,不过rownum对于指定编号区间的输出应该说更强大SELECT *FROM (SELECT a.*, ROWNUM rn FROM torderdetail a) WHERE rn = 10 AND rn = 20 这条语句即是输出第10到第20条纪录,这里之所以用rownum rn,是把rownum转成实例,因为rownum本身只能用 =的比较方式,只有转成实列,这样就可做 =的比较了。 在实际用途中,常常会要求取最近的几条纪录,这就需要先对纪录进行排序后再取rownum =一般常见的SELECT *FROM (SELECT a.* FROM torderdetail a ORDER BY order_date DESC) WHERE ROWNUM = 10 而在CSDN曾经发生过讨论,关于取近的10条纪录,有人给出这样的语句SELECT a.* FROM torderdetail a WHERE ROWNUM = 10 ORDER BY order_date DESC 之所以会出现这样的语句,主要是从效率上的考虑,前面条语句,是要进行全表扫描后再排序,然后再取10条纪录,后一条语句则不会全表扫描,只会取出10条纪录,很明显后条语句的效率会高许多。 那为什么会有争议呢,那就在于在执行顺序上争议,是先执行排序取10条纪录,还是取10条纪录,再排序呢?两种顺序取出来的结果是截然相反的,先排序再取10条,就是取最近的10条,而先取10条,再排序,则取出的最早的10条纪录。对于此语句,普遍的认为执行顺序是先取10条纪录再排序的。所以此语句应该是错误。但实际上并非如此,此语句的执行顺序和order by的字段有关系,如果你order by 的字段是pk,则是先排序,再取10条(速度比第一种语句快),而排序字段不是PK 时,是先取10条再排序,此时结果就与要求不一样了,所以第二种写法一定要在排序字段是主键的情况下才能保证结果正确。 Row_number() over()这个分析函数是从9I开始提供的,一般的用途和rownum差不多。 一般写法row_number() over( order by order_date desc) 生成的顺序和rownum的语句一样,效率也一样(对于同样有order by 的rownum语句来说),所以在这种情况下两种用法是一样的。 而对于分组后取最近的10条纪录,则是rownum无法实现的,这时只有row_number可以实现,row_number() over(partition by 分组字段 order by 排序字段)就能实现分组后编号,比如说要取近一个月的每天最后10个订单纪录SELECT *FROM (SELECT a.*, ROW_NUMBER () OVER (PARTITION BY TRUNC (order_date) ORDER BY order_date DESC)rnFROM torderdetail a)
创新新互联,凭借十余年的网站设计、网站建设经验,本着真心·诚心服务的企业理念服务于成都中小企业设计网站有上千多家案例。做网站建设,选成都创新互联公司。
Oracle常用的命令如何查看表的结构
以下的文章主要是介绍Oracle常用的命令中如何查看表的结构.EDITDATA 表名;修改表字段:Alter table 表名 modify(字段名 类型 约束);alter table test modify (addd varchar2(10) null); alter table 表名 add(字段名 类型 约束);alter table test add(age varchar2(5)); 1.登陆系统用户在Oracle常用命令中查看表结构sqlplus 然后输入系统用户名和密码登陆别的用户conn 用户名/密码;2.创建表空间create tablespace 空间名 datafile 'c:\空间名' size 15M --表空间的存放路径,初始值为15M autoExtend on next 10M --空间的自动增长的值是10M permanent online; --永久使用 3.创建用户create user shi --创建用户名为shi identified by scj --创建密码为scj default tablespace 表空间名 --默认表空间名 temporary tablespace temp --临时表空间为temp profile default --受profile文件的限制 quota unlimited on 表空间名; --在表空间下面建表不受限制 4.创建角色create role 角色名 identified by 密码;5.给角色授权grant create session to 角色名;--给角色授予创建会话的权限grant 角色名 to 用户名; --把角色授予用户6.给用户授予权限grant connect,resource to shi;--给shi用户授予所有权限 Grant dba to shi;-给shi 用户授予DBA权限 grant create table to shi; --给shi用户授予创建表的权限 7.select table_name from user_tables; 察看当前用户下的所有表8.select tablespace_name from user_tablespaces; 察看当前用户下的 表空间9.select username from dba_users;察看所有用户名称命令 必须用sys as sysdba登陆10.创建表create table 表名( id int not null, name varchar2(20) not null )tablespace 表空间名 --所属的表空间 storage ( initial 64K --表的初始值 minextents 1 --最小扩展值 maxextents unlimited --最大扩展值 ); 11.为usrs表添加主键和索引alter table users add constraint pk primary key (ID); 12.为已经创建users表添加外键alter table users add constraint fk_roleid foreign key (roleid) references role(role_id) on delete cascad; --下边写主表的列 on delete cascad是创建级联 13.把两个列连接起来select concat(name,id) from 表名; --把name和id连接起来14.截取字符串select column(name,'李') from 表名;把name中的‘李’去掉15.运行事务之前必须写set serveroutput on; 打开输入输出(不写的话,打印不出信息)16.while的应用declare --声明部分 ccc number:=1; --复职 a number:=0; begin --事务的开始 while ccc=100 loop --循环 if((ccc mod 3)=0) then --条件 dbms_output.put_line(ccc||','); --打印显示 aa:=a+ccc; end if; --结束if cc:=ccc+1; end loop; --结束循环 dbms_output.put_line(a); end; --结束事务 / 17.select into 的用法 --只能处理一行结果集declare name varchar(30); begin select username into name from users where id=2; dbms_output.put_line('姓名为:'||name); end; / 上述的相关内容就是对Oracle常用命令中查看表结构的描述,希望会给你带来一些帮助在此方面。
Oracle中怎样查看所有的表,列,属性,主键等信息
1、首先开启Oracle管理工具,找到Tablespaces。
2、首先要看的是表空间的总大小和使用状况以及当前状态。
3、Free Space 里面是各个表中的相关大小信息(一个表空间可能有多个表在使用)。
4、Objects 就如第三步中所提到的使用这个表空间的表明细。
5、Script 是创建表空间的PL/SQL,可以去了解它的相关信息和学习怎么创建表空间文件。
在Oracle中怎样查询前10条记录?
下面是关于rownum的介绍
================================
rownum和row_number()
over()的使用
rownum是oracle从8开始提供的一个伪列,是把sql出来的结果进行编号,始终从1开始,常见的用途就是用来分页输出.
比如select
*from
torderdetail
a
where
rownum
=
10
这条语句就是输出前10条纪录,在这里用途上类似于sql
sever的top,不过rownum对于指定编号区间的输出应该说更强大select
*from
(select
a.*,
rownum
rn
from
torderdetail
a)
where
rn
=
10
and
rn
=
20
这条语句即是输出第10到第20条纪录,这里之所以用rownum
rn,是把rownum转成实例,因为rownum本身只能用
=的比较方式,只有转成实列,这样就可做
=的比较了。
在实际用途中,常常会要求取最近的几条纪录,这就需要先对纪录进行排序后再取rownum
=一般常见的select
*from
(select
a.*
from
torderdetail
a
order
by
order_date
desc)
where
rownum
=
10
而在csdn曾经发生过讨论,关于取近的10条纪录,有人给出这样的语句select
a.*
from
torderdetail
a
where
rownum
=
10
order
by
order_date
desc
之所以会出现这样的语句,主要是从效率上的考虑,前面条语句,是要进行全表扫描后再排序,然后再取10条纪录,后一条语句则不会全表扫描,只会取出10条纪录,很明显后条语句的效率会高许多。
那为什么会有争议呢,那就在于在执行顺序上争议,是先执行排序取10条纪录,还是取10条纪录,再排序呢?两种顺序取出来的结果是截然相反的,先排序再取10条,就是取最近的10条,而先取10条,再排序,则取出的最早的10条纪录。对于此语句,普遍的认为执行顺序是先取10条纪录再排序的。所以此语句应该是错误。但实际上并非如此,此语句的执行顺序和order
by的字段有关系,如果你order
by
的字段是pk,则是先排序,再取10条(速度比第一种语句快),而排序字段不是pk
时,是先取10条再排序,此时结果就与要求不一样了,所以第二种写法一定要在排序字段是主键的情况下才能保证结果正确。
row_number()
over()这个分析函数是从9i开始提供的,一般的用途和rownum差不多。
一般写法row_number()
over(
order
by
order_date
desc)
生成的顺序和rownum的语句一样,效率也一样(对于同样有order
by
的rownum语句来说),所以在这种情况下两种用法是一样的。
当前文章:oracle怎么查看pk oracle怎么查看锁表
本文链接:http://scgulin.cn/article/hgcsgh.html