oracle怎么查條數(shù)據(jù),oracle怎么查數(shù)據(jù)庫中的空行數(shù)據(jù)

Oracle查詢前幾條數(shù)據(jù)的方法

由于Oracle不支持select top 語句,所以在Oracle中經(jīng)常是用order by 跟rownum 的組合來實(shí)現(xiàn)select top n的查詢。 簡單地說,實(shí)現(xiàn)方法如下所示: select 列名1 ...列名n from(select 列名1 ...列名n from 表名 order by 列名1)where rownum =N(抽出記錄數(shù)) order by rownum asc 如:select id,name from (select id,name from student order by name) where rownum=10 order by rownum asc 按姓名排序取出前十條數(shù)據(jù) 附:取100-150條數(shù)據(jù)的方法1. 最佳選擇:利用分析函數(shù) row_number() over ( partition by col1 order by col2 )比如想取出100-150條記錄,按照tname排序 select tname,tabtype from ( select tname,tabtype,row_number() over ( order by tname ) rn from tab ) where rn between 100 and 150; 2. 使用rownum 虛列 select tname,tabtype from ( select tname,tabtype,rownum rn from tab

專注于為中小企業(yè)提供成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)灌陽免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了千余家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

在oracle中,如何從一張表中查詢一條隨機(jī)記錄

這幾天工作上的需要,要從一個(gè)比較大的表中隨機(jī)取出一條記錄,oracle 不像MS SQLSERVER那樣,直接用Select TOP 1 * From TABLE Order By NewID(),就能高效的隨機(jī)查出一條記錄。經(jīng)過一翻折騰,用一個(gè)有90萬條記錄的表t_id,只有一個(gè)gameid字段,該字段上沒有索引,表里就是從100000到999999一連串的數(shù)據(jù)記錄,進(jìn)行測(cè)試:

方法1.

采用rownum和dbms_random.value,平均用時(shí)5秒,這個(gè)效率確實(shí)是太低了,對(duì)于小表應(yīng)該還行,大表那就太不適合了。

declare

n_id number(6);

begin

SELECT gameid into n_id FROM(SELECT gameid FROM t_id T ORDER BY dbms_random.value()) WHERE ROWNUM=1;

dbms_output.put_line(to_char(n_id));

end;

/

方法2. 

采用oracle sample語法,設(shè)置隨機(jī)樣本是1%,結(jié)果用時(shí)0.01左右,速度是相當(dāng)快的,但是根據(jù)官網(wǎng)的說法,采用sample采集特性可能會(huì)產(chǎn)生不準(zhǔn)確的結(jié)果集,我在測(cè)試中是沒有碰到不正確的結(jié)果。但是有個(gè)問題,就是隨機(jī)的結(jié)果分布很不平均,結(jié)果幾乎都分內(nèi)存卡在100000-200000的記錄中。效率雖好,但并沒有達(dá)到很好的隨機(jī)效果,如果對(duì)于結(jié)果的要求不是很高的,這個(gè)方法是相當(dāng)不錯(cuò)的。

declare

n_id number(6);

begin

SELECT gameid into n_id FROM t_id SAMPLE (1) WHERE ROWNUM = 1;

dbms_output.put_line(to_char(n_id));

end;

/

方法3. 

采用minus語法,先隨機(jī)獲取一個(gè)在表總記錄數(shù)范圍內(nèi)的一個(gè)隨機(jī)數(shù),再通過rownum查詢兩個(gè)結(jié)果集只相差一條記錄,用minus相減留出事先隨機(jī)數(shù)的那條記錄,平均用時(shí)大概1秒,隨機(jī)數(shù)越小,查詢速度越快,當(dāng)隨機(jī)數(shù)是20000時(shí),用于0.016秒。該方法雖然

能得到很有隨機(jī)效果,但效率比較不上該方法2. 對(duì)效率要求一般的話, 還是可以考慮使用的。

declare

n_count int:=0;

n_rand_num int:=0;

n_id number(6);

begin

SELECT COUNT(*) INTO n_count FROM t_id;

SELECT trunc(dbms_random.value(1,n_count+1)) INTO n_rand_num FROM DUAL;

select gameid into n_id from (SELECT gameid FROM t_id T WHERE rownumn_rand_num

minus

SELECT gameid FROM t_id T WHERE rownumn_rand_num-1);

dbms_output.put_line(to_char(n_id));

end;

/

oracle怎么通過索引查詢數(shù)據(jù)語句

oracle對(duì)于數(shù)據(jù)庫中的表信息,存儲(chǔ)在系統(tǒng)表中。查詢已創(chuàng)建好的表索引,可通過相應(yīng)的sql語句到相應(yīng)的表中進(jìn)行快捷的查詢:\x0d\x0a1. 根據(jù)表名,查詢一張表的索引\x0d\x0a\x0d\x0aselect * from user_indexes where table_name=upper('表名');\x0d\x0a\x0d\x0a2. 根據(jù)索引號(hào),查詢表索引字段\x0d\x0a\x0d\x0aselect * from user_ind_columns where index_name=('索引名');\x0d\x0a\x0d\x0a3.根據(jù)索引名,查詢創(chuàng)建索引的語句\x0d\x0a\x0d\x0aselect dbms_metadata.get_ddl('INDEX','索引名', ['用戶名']) from dual ; --['用戶名']可省,默認(rèn)為登錄用戶\x0d\x0a\x0d\x0aPS:dbms_metadata.get_ddl還可以得到建表語句,如:\x0d\x0a\x0d\x0aSELECT DBMS_METADATA.GET_DDL('TABLE','表名', ['用戶名']) FROM DUAL ; //取單個(gè)表的建表語句,['用戶名']可不輸入,默認(rèn)為登錄用戶\x0d\x0aSELECT DBMS_METADATA.GET_DDL('TABLE',u.table_name) FROM USER_TABLES u; //取用戶下所有表的建表語句\x0d\x0a\x0d\x0a當(dāng)然,也可以用pl/sql developer工具來查看相關(guān)的表的各種信息。

如何在oracle中查詢每個(gè)表的記錄條數(shù)

如何在oracle中查詢每個(gè)表的記錄條數(shù)

可用兩種方法,一種是在oracle的系統(tǒng)表中統(tǒng)計(jì),另一種需要寫存儲(chǔ)過程統(tǒng)計(jì),方法分別如下。

1、系統(tǒng)表中統(tǒng)計(jì):

1

SELECT sum(num_rows) FROM user_tables;

結(jié)果:

2、存儲(chǔ)過程統(tǒng)計(jì),代碼如下:

declare

v_tName varchar(50);

v_sqlanalyze varchar(500);

v_num number;

v_sql varchar(500);

cursor c1

is

select table_name from user_tables;

begin

open c1;

loop

fetch c1 into v_tName;

if c1%found then

v_sqlanalyze :='analyze table '||v_tName||' estimate statistics';

execute immediate v_sqlanalyze;

v_sql := 'select NUM_ROWS from user_tables where table_name =upper('''||v_tName||''')';

execute immediate v_sql into v_num;

dbms_output.put_line('表名: '||v_tName||' 行數(shù): '||v_num);

else

exit;

end if;

end loop;

end;

Oracle之查詢?cè)斀?/h2>

查詢是數(shù)據(jù)的一個(gè)重要操作。用戶發(fā)送查詢請(qǐng)求,經(jīng)編譯軟件變異成二進(jìn)制文件供服務(wù)器查詢,后返回查詢結(jié)果集給用戶,查詢會(huì)產(chǎn)生一個(gè)虛擬表,看到的是表形式顯示的結(jié)果,但結(jié)果并不真正的存儲(chǔ),每次執(zhí)行查詢只是從數(shù)據(jù)表中提取數(shù)據(jù),并按照表的形式顯示出來。

SELECT 列名

FGROM 表名

[WHERE 查詢條件表達(dá)式]

[GROUP BY 分組表達(dá)式]

[HAVING 分組查詢表達(dá)式]

[ORDER BY 排序的列名 [ASC或DESC]]

group by 用于對(duì)查詢的結(jié)果分組統(tǒng)計(jì),通過對(duì)group by后面的名字進(jìn)行分組后輸出結(jié)果。

group by后面還可以跟多列表示 多列分組 ,在多列分組時(shí)放前面的優(yōu)先分組。

group by 列名,列名

having 子句用于限制分組顯示結(jié)果,其只能和group by一起連用。在where中沒有辦法直接使用聚合函數(shù),即sum avg等無法使用,所以引用了having,在having中可以使用這些函數(shù)。

order by 表示排序,后跟列名和排序方式。如果什么都不加默認(rèn)為升序。ASC表示升序,DESC表示降序。

在Oracle中還可以設(shè)置多列排序

order by 列名1 升降,列名2 升降;

前面的為主要排序,后面的為次一級(jí)排序。

注:碰到自己與自己比較的情況下,不能用having,可以創(chuàng)建一個(gè)新列。

注:如果select語句同時(shí)包含group by,having,order by,按group by,having,order by排序

分組和聚合一起使用,目的是為了統(tǒng)計(jì)信息。

where是為了from服務(wù)的,只能跟 真實(shí)的字段 ,用來篩選from子句中指定的操作所產(chǎn)生的行

group by 用來分組where子句的輸出

having 用來從分組的結(jié)果中篩選行

order by用來對(duì)篩選的結(jié)果進(jìn)行排序

(1)分組函數(shù):max min?avg sum count

max表示該列的最大值,min表示該列的最小值,avg表示該列的平均值,sum表示該列的和,count表示該列的行數(shù)。

注:分組函數(shù)(max、min、avg、count、sum)只能出現(xiàn)在選擇列表中having子句、order by子句、不能出現(xiàn)在where子句和group by子句中。

(2)多表查詢

多表查詢是指兩個(gè)和兩個(gè)以上的表或者是視圖的查詢,在實(shí)際應(yīng)用中,當(dāng)查詢單個(gè)表不能滿足需求時(shí),一般使用多表查詢。如:顯示sales部門位置和其員工的姓名,這種情況下需要使用到(dept表和emp表)。

多表查詢的連接一般可以分為:內(nèi)連接、左外連接、右外連接、全連接。

注:在使用多表查詢的時(shí)候每個(gè)表可以設(shè)置別名,如果表指定了別名,那么語句中所有語句必須使用別名,而不能再使用實(shí)際表名。且在寫屬性的時(shí)候如果屬性為其中一個(gè)表特有的屬性則不需要寫別名,如果是兩個(gè)表都有則必須指定是哪一個(gè)表的哪個(gè)屬性格式為:表名.屬性名。

select 列名 from 表1 別名,表2 別名...

注:e是emp的別名,d是dept的別名。

但如果對(duì)表進(jìn)行了操作則需要設(shè)置別名,如:查詢每個(gè)部門中工資高于該部門平均工資的員工人數(shù)。在其中有一個(gè)avg表,這個(gè)表必須設(shè)置別名(提醒:如果僅有一個(gè)被修改的表,則可以不設(shè)置別名,但如果有多個(gè)表則必須設(shè)置別名)。

內(nèi)連接

內(nèi)連接通過使用比較運(yùn)算符來使每個(gè)表的通用列中的值匹配來組成一個(gè)新表,即:把兩個(gè)表中間共有的那些行拿出來進(jìn)行連接,如果某些行不是兩個(gè)表共有的,則不進(jìn)行連接。

select

from 表1

inner join 表2

on 匹配條件

select

from 表1 表2

where匹配條件

左外連接

左外連接與內(nèi)連接的區(qū)別是:設(shè)置左外連接的時(shí)候設(shè)置了主表和附表,主表在前,附表在后。內(nèi)連接是將兩個(gè)表匹配的地方輸出出來,而左外連接則是主表全寫,附表一一對(duì)應(yīng),附表有則加上,沒有不寫。

select

from 表1

left join 表2

on 匹配條件

右外連接

右外連接和左外連接基本相同只是右外連接的主表寫在后邊。

select

from 表1

right join 表2

on 匹配條件

全連接

全連接是在等值連接的基礎(chǔ)上將左表和右表的未匹配數(shù)據(jù)都加上,使用的關(guān)鍵字為full outer join或者full join。

select

from 表1

full join 表2

on 匹配條件

自連接

還有一種特殊情況即自連接,在Oracle中一個(gè)表無法與自己進(jìn)行比較,所以當(dāng)需要自己表的兩個(gè)信息做比較的時(shí)候也需要使用連接來連接,即同一張表的連結(jié)查詢。

(3)子查詢

子查詢是指嵌套在其他sql語句中的select語句,也叫嵌套查詢。sql語句執(zhí)行順序?yàn)閺挠业阶髨?zhí)行,所以在執(zhí)行查詢時(shí)會(huì)先執(zhí)行左側(cè)的子查詢后進(jìn)行主查詢。

子查詢分為單行子查詢和多行子查詢,單行子查詢是指返回一行數(shù)據(jù)的子查詢語句,多行子查詢是指返回多行數(shù)據(jù)的查詢語句。子查詢還可以分為多列子查詢、多行子查詢、多列多行子查詢。

在進(jìn)行子查詢時(shí)如果內(nèi)部查詢不返回任何記錄,則外部條件中字段DEPTNO與NULL比較永遠(yuǎn)為假,也就是說外部查詢不返回任何結(jié)果。

總結(jié)為:

單行子查詢是指子查詢只返回單列、單行數(shù)據(jù)

多行子查詢是指返回單列多行數(shù)據(jù),都是針對(duì)單列而言的

多列子查詢則是指查詢返回多個(gè)列數(shù)據(jù)的子查詢語句

單行子查詢

where deptno = (單行數(shù)值)

多行子查詢

where deptno in ( 多行數(shù)值 )

多列子查詢:

where (job,deptno)=(select job,deptno from emp where ename='KING')

多列多行子查詢

where (job,deptno) in (select job,deptno from emp where ename='KING')

單行子查詢

在單行子查詢的外部查詢中可以使用=、、、=、=、等比較運(yùn)算符。

內(nèi)部查詢返回的結(jié)果必須與外部查詢條件中字段(DEPTNO)相匹配。

多行子查詢

在WHERE子句中使用多行子查詢時(shí),可以使用多行比較運(yùn)算符(IN,ALL,ANY)。

IN:等于任何一個(gè)。

ALL:和子查詢返回的所有值比較。例如:salALL(1,2,3)等價(jià)于sal3,即大于所有。

ANY:和子查詢返回的任意一個(gè)值比較。例如:salANY(1,2,3)等價(jià)于sal1,即大于任意一個(gè)就可以。

注:ANY運(yùn)算符必須與單行比較運(yùn)算符結(jié)合使用,并且返回行只要匹配子查詢的任何一個(gè)結(jié)果即可。

多列子查詢

多列子查詢和多行子查詢相同,只是使用多列子查詢的時(shí)候會(huì)有多列進(jìn)行匹配。

(4)集合運(yùn)算

為了合并多個(gè)select語句的結(jié)果,可以使用集合操作符號(hào)union,union all,intersect,minus。

union:該操作符用于取得兩個(gè)結(jié)果集的并集。當(dāng)使用該操作符時(shí),會(huì)自動(dòng)去掉結(jié)果集中重復(fù)行

union all:該操作與union相似,但是它不會(huì)取消重復(fù)行,而且不會(huì)排序

intersect:使用該操作符用于取得兩個(gè)結(jié)果集的交集

minus:使用該操作符用于取得兩個(gè)結(jié)果集的差集,它只會(huì)顯示存在第一個(gè)集合中,而不存在第二個(gè)集合中的數(shù)據(jù)

總結(jié)為集合運(yùn)算就是將兩個(gè)或者多個(gè)結(jié)果集組合成一個(gè)結(jié)果集。

intersect ?交集 返回兩個(gè)查詢共有的記錄

union all ?并集 返回各個(gè)查詢的所有記錄,包括重復(fù)的記錄

union ? ? ?交集 返回各個(gè)查詢的所有記錄,不包括重復(fù)的記錄

MINUS ? 補(bǔ)集 返回第一個(gè)查詢檢查出的記錄減去第二個(gè)查詢檢索出來的記錄之后剩余的記錄

注意:當(dāng)使用集合操作的時(shí)候,查詢所返回的列數(shù)以及列的類型必須匹配,列名可以不同。

(1)Distinct關(guān)鍵字

在Oracle中,可能出現(xiàn)若干相同的情況,那么可以用Distinct消除重復(fù)行

(2)多表查詢與單行子查詢可以實(shí)現(xiàn)相同的功能

查詢出銷售部(sales)下面的員工姓名,工作,工資

(3)顯示高于自己部門平均工資的員工信息

分析:

1.找到所有部門的平均工資

select deptno,avg(sal) from emp group by deptno;

2.找到所有人的工資信息

select ename,sal,deptno from emp;

3.把兩個(gè)結(jié)果集使用多表連接組合組合起來

select * from emp,(select deptno,avg(sal) avgsal from emp group by deptno) damao where emp.deptno=damao.deptno;

4.去掉低于平均工資的那些數(shù)據(jù)即可:

select * from emp,(select deptno,avg(sal) avgsal from emp group by deptno) damao where emp.deptno=damao.deptno and salavgsal;

(4)emp表介紹

字段? ? ? ? ? ? ? 類型? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 描述

empno ? ? ? ? ?NUMBER(4) ? ? ? ? ? ? ? ? 表示雇員編號(hào),是唯一編號(hào)

ename ? ? ? ? ?VAECHAR2(10) ? ? ? ? ? 表示雇員姓名

job ? ? ? ? ? ? ? ?VARCHAR2(9) ? ? ? ? ? ? 表示工作職位

mgr ? ? ? ? ? ? ?NUMBER(4) ? ? ? ? ? ? ? ? 表示一個(gè)雇員的領(lǐng)導(dǎo)編號(hào)

hiredate ? ? ? DATE ? ? ? ? ? ? ? ? ? ? ? ? ? ?表示雇傭日期

sal ? ? ? ? ? ? ? NUMBER(7,2) ? ? ? ? ? ? ? 表示月薪,工資

comm ? ? ? ? ?NUMBER(7,2) ? ? ? ? ? ? ? 表示獎(jiǎng)金,或者稱為傭金

deptno ? ? ? ? NUMBER(2) ? ? ? ? ? ? ? ? 部門編號(hào)

當(dāng)前文章:oracle怎么查條數(shù)據(jù),oracle怎么查數(shù)據(jù)庫中的空行數(shù)據(jù)
轉(zhuǎn)載來源:http://muchs.cn/article24/pheice.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、網(wǎng)站建設(shè)、動(dòng)態(tài)網(wǎng)站、關(guān)鍵詞優(yōu)化、網(wǎng)站內(nèi)鏈、網(wǎng)頁設(shè)計(jì)公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)