亚洲免费不卡_在线视频精品_国产尤物精品_久久久久网址_久久精品91_欧美va天堂在线_狠狠入ady亚洲精品_亚洲午夜精品福利_国产精品草草_午夜精品久久99蜜桃的功能介绍

oracle sql select語句的使用方法
來源:易賢網 閱讀:3350 次 日期:2014-09-16 15:56:15
溫馨提示:易賢網小編為您整理了“oracle sql select語句的使用方法”,方便廣大網友查閱!

select格式:

SELECT [ ALL | DISTINCT ] <字段表達式1[,<字段表達式2[,…]

FROM <表名1>,<表名2>[,…]

[WHERE <篩選擇條件表達式>]

[GROUP BY <分組表達式> [HAVING<分組條件表達式>]]

[ORDER BY <字段>[ASC | DESC]]

語句說明:

[]方括號為可選項

[GROUP BY <分組表達式> [HAVING<分組條件表達式>]]

指將結果按<分組表達式>的值進行分組,該值相等的記錄為一組,帶【HAVING】

短語則只有滿足指定條件的組才會輸出。

[ORDER BY <字段>[ASC | DESC]]

顯示結果要按<字段>值升序或降序進行排序

練習:

1:表hkb_test_sore取出成績sore前5名的記錄,

2:取第5名的記錄

1,答案select a.sore_id, a.sore

from (select * from hkb_test_sore order by sore desc) a

where rownum <=5

2,答案select a.sore_id, a.sore

from (select * from hkb_test_sore order by sore desc) a

where rownum <=5

minus

select a.sore_id, a.sore

from (select * from hkb_test_sore order by sore desc) a

where rownum <=4;

3:查詢兩個分數一樣的記錄

select *

from hkb_test_sore a

where a.sore = (select sore

from hkb_test_sore a

group by a.sore

having count(a.sore) = 2);

union,union all,intersect,minus的區別:

SQL> select * from hkb_test2;

X Y

---- -----

a 1

b 2

c 3

g 4

SQL> select * from hkb_test3;

X Y

---- -----

a 1

b 2

e 3

f 4

SQL> select * from hkb_test2;

X Y

---- -----

a 1

b 2

c 3

g 4

SQL> select * from hkb_test3;

X Y

---- -----

a 1

b 2

e 3

f 4

SQL> select * from hkb_test2

2 union

3 select * from hkb_test3;

X Y

---- -----

a 1

b 2

c 3

e 3

f 4

g 4

6 rows selected

SQL> select * from hkb_test2

2 union all

3 select * from hkb_test3;

X Y

---- -----

a 1

b 2

c 3

g 4

a 1

b 2

e 3

f 4

8 rows selected

SQL> select * from hkb_test2

2 intersect

3 select * from hkb_test3;

X Y

---- -----

a 1

b 2

SQL> select * from hkb_test2

2 minus

3 select * from hkb_test3;

X Y

---- -----

c 3

g 4

綜合上面實例看個完整的實例

SQL>

SQL>

SQL> -- create demo table

SQL> create table Employee(

2 ID VARCHAR2(4 BYTE) NOT NULL primary key,

3 First_Name VARCHAR2(10 BYTE),

4 Last_Name VARCHAR2(10 BYTE),

5 Start_Date DATE,

6 End_Date DATE,

7 Salary Number(8,2),

8 City VARCHAR2(10 BYTE),

9 Description VARCHAR2(15 BYTE)

10 )

11 /

Table created.

SQL>

SQL> -- prepare data

SQL> insert into Employee(ID, First_Name, Last_Name, Start_Date, End_Date, Salary, City, Description)

2 values ('01','Jason', 'Martin', to_date('19960725','YYYYMMDD'), to_date('20060725','YYYYMMDD'), 1234.56, 'Toronto', 'Programmer')

3 /

1 row created.

SQL> insert into Employee(ID, First_Name, Last_Name, Start_Date, End_Date, Salary, City, Description)

2 values('02','Alison', 'Mathews', to_date('19760321','YYYYMMDD'), to_date('19860221','YYYYMMDD'), 6661.78, 'Vancouver','Tester')

3 /

1 row created.

SQL> insert into Employee(ID, First_Name, Last_Name, Start_Date, End_Date, Salary, City, Description)

2 values('03','James', 'Smith', to_date('19781212','YYYYMMDD'), to_date('19900315','YYYYMMDD'), 6544.78, 'Vancouver','Tester')

3 /

1 row created.

SQL> insert into Employee(ID, First_Name, Last_Name, Start_Date, End_Date, Salary, City, Description)

2 values('04','Celia', 'Rice', to_date('19821024','YYYYMMDD'), to_date('19990421','YYYYMMDD'), 2344.78, 'Vancouver','Manager')

3 /

1 row created.

SQL> insert into Employee(ID, First_Name, Last_Name, Start_Date, End_Date, Salary, City, Description)

2 values('05','Robert', 'Black', to_date('19840115','YYYYMMDD'), to_date('19980808','YYYYMMDD'), 2334.78, 'Vancouver','Tester')

3 /

1 row created.

SQL> insert into Employee(ID, First_Name, Last_Name, Start_Date, End_Date, Salary, City, Description)

2 values('06','Linda', 'Green', to_date('19870730','YYYYMMDD'), to_date('19960104','YYYYMMDD'), 4322.78,'New York', 'Tester')

3 /

1 row created.

SQL> insert into Employee(ID, First_Name, Last_Name, Start_Date, End_Date, Salary, City, Description)

2 values('07','David', 'Larry', to_date('19901231','YYYYMMDD'), to_date('19980212','YYYYMMDD'), 7897.78,'New York', 'Manager')

3 /

1 row created.

SQL> insert into Employee(ID, First_Name, Last_Name, Start_Date, End_Date, Salary, City, Description)

2 values('08','James', 'Cat', to_date('19960917','YYYYMMDD'), to_date('20020415','YYYYMMDD'), 1232.78,'Vancouver', 'Tester')

3 /

1 row created.

SQL>

SQL>

SQL>

SQL> -- display data in the table

SQL> select * from Employee

2 /

ID FIRST_NAME LAST_NAME START_DAT END_DATE SALARY CITY DESCRIPTION

---- -------------------- -------------------- --------- --------- ---------- ---------- ---------------

01 Jason Martin 25-JUL-96 25-JUL-06 1234.56 Toronto Programmer

02 Alison Mathews 21-MAR-76 21-FEB-86 6661.78 Vancouver Tester

03 James Smith 12-DEC-78 15-MAR-90 6544.78 Vancouver Tester

04 Celia Rice 24-OCT-82 21-APR-99 2344.78 Vancouver Manager

05 Robert Black 15-JAN-84 08-AUG-98 2334.78 Vancouver Tester

06 Linda Green 30-JUL-87 04-JAN-96 4322.78 New York Tester

07 David Larry 31-DEC-90 12-FEB-98 7897.78 New York Manager

08 James Cat 17-SEP-96 15-APR-02 1232.78 Vancouver Tester

8 rows selected.

SQL>

SQL>

SQL> SELECT id, first_name, last_name FROM employee

2 /

ID FIRST_NAME LAST_NAME

---- -------------------- --------------------

01 Jason Martin

02 Alison Mathews

03 James Smith

04 Celia Rice

05 Robert Black

06 Linda Green

07 David Larry

08 James Cat

8 rows selected.

在ORACLE中實現SELECT TOP N的方法

1.在ORACLE中實現SELECT TOP N

由于ORACLE不支持SELECT TOP語句,所以在ORACLE中經常是用ORDER BY跟ROWNUM的組合來實現SELECT TOP N的查詢。

簡單地說,實現方法如下所示:

SELECT 列名1...列名n FROM

(SELECT 列名1...列名n FROM 表名 ORDER BY 列名1...列名n)

WHERE ROWNUM <= N(抽出記錄數)

ORDER BY ROWNUM ASC

下面舉個例子簡單說明一下。

顧客表customer(id,name)有如下數據:

ID NAME

01 first

02 Second

03 third

04 forth

05 fifth

06 sixth

07 seventh

08 eighth

09 ninth

10 tenth

11 last

則按NAME的字母順抽出前三個顧客的SQL語句如下所示:

SELECT * FROM

(SELECT * FROM CUSTOMER ORDER BY NAME)

WHERE ROWNUM <= 3

ORDER BY ROWNUM ASC

輸出結果為:

ID NAME

08 eighth

05 fifth

01 first

2.在TOP N紀錄中抽出第M(M <= N)條記錄

在得到了TOP N的數據之后,為了抽出這N條記錄中的第M條記錄,我們可以考慮從ROWNUM著手。我們知道,ROWNUM是記錄表中數據編號的一個隱藏子段,所以可以在得到TOP N條記錄的時候同時抽出記錄的ROWNUM,然后再從這N條記錄中抽取記錄編號為M的記錄,即使我們希望得到的結果。

從上面的分析可以很容易得到下面的SQL語句。

SELECT 列名1...列名n FROM

(

SELECT ROWNUM RECNO, 列名1...列名nFROM

(SELECT 列名1...列名n FROM 表名 ORDER BY 列名1...列名n)

WHERE ROWNUM <= N(抽出記錄數)

ORDER BY ROWNUM ASC

)

WHERE RECNO = M(M <= N)

同樣以上表的數據為基礎,那么得到以NAME的字母順排序的第二個顧客的信息的SQL語句應該這樣寫:

SELECT ID, NAME FROM

(

SELECT ROWNUM RECNO, ID, NAME FROM

(SELECT * FROM CUSTOMER ORDER BY NAME)

WHERE ROWNUM <= 3

ORDER BY ROWNUM ASC )

WHERE RECNO = 2

結果則為:

ID NAME

05 fifth

3.抽出按某種方式排序的記錄集中的第N條記錄

在2的說明中,當M = N的時候,即為我們的標題講的結果。實際上,2的做法在里面N>M的部分的數據是基本上不會用到的,我們僅僅是為了說明方便而采用。

如上所述,則SQL語句應為:

SELECT 列名1...列名n FROM

(

SELECT ROWNUM RECNO, 列名1...列名nFROM

(SELECT 列名1...列名n FROM 表名 ORDER BY 列名1...列名n)

WHERE ROWNUM <= N(抽出記錄數)

ORDER BY ROWNUM ASC

)

WHERE RECNO = N

那么,2中的例子的SQL語句則為:

SELECT ID, NAME FROM

(

SELECT ROWNUM RECNO, ID, NAME FROM

(SELECT * FROM CUSTOMER ORDER BY NAME)

WHERE ROWNUM <= 2

ORDER BY ROWNUM ASC

)

WHERE RECNO = 2

結果為:

ID NAME

05 fifth

4.抽出按某種方式排序的記錄集中的第M條記錄開始的X條記錄

3里所講得僅僅是抽取一條記錄的情況,當我們需要抽取多條記錄的時候,此時在2中的N的取值應該是在N >= (M + X - 1)這個范圍內,當讓最經濟的取值就是取等好的時候了的時候了。當然最后的抽取條件也不是RECNO = N了,應該是RECNO BETWEEN M AND (M + X - 1)了,所以隨之而來的SQL語句則為:

SELECT 列名1...列名n FROM

(

SELECT ROWNUM RECNO, 列名1...列名nFROM

(

SELECT 列名1...列名n FROM 表名 ORDER BY 列名1...列名n)

WHERE ROWNUM <= N (N >= (M + X - 1))

ORDER BY ROWNUM ASC

)

WHERE RECNO BETWEEN M AND (M + X - 1)

同樣以上面的數據為例,則抽取NAME的字母順的第2條記錄開始的3條記錄的SQL語句為:

SELECT ID, NAME FROM

(

SELECT ROWNUM RECNO, ID, NAME FROM

(SELECT * FROM CUSTOMER ORDER BY NAME)

WHERE ROWNUM <= (2 + 3 - 1)

ORDER BY ROWNUM ASC

)

WHERE RECNO BETWEEN 2 AND (2 + 3 - 1)

更多信息請查看IT技術專欄

更多信息請查看數據庫
易賢網手機網站地址:oracle sql select語句的使用方法
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點

版權所有:易賢網

亚洲免费不卡_在线视频精品_国产尤物精品_久久久久网址_久久精品91_欧美va天堂在线_狠狠入ady亚洲精品_亚洲午夜精品福利_国产精品草草_午夜精品久久99蜜桃的功能介绍
久久综合久久久| 亚洲人成网站在线观看播放| 午夜精品一区二区三区四区| 欧美国产高潮xxxx1819| 国产一区自拍视频| 亚洲三级影院| 亚洲免费中文| 欧美涩涩网站| 国产精品久久久亚洲一区| 麻豆精品网站| 激情综合网址| 麻豆成人av| 亚洲经典自拍| 午夜一级在线看亚洲| 国产综合18久久久久久| 国产精品乱码| 亚洲国产网站| 女人天堂亚洲aⅴ在线观看| 激情欧美国产欧美| 欧美成熟视频| 亚洲一区二区三区四区五区午夜| 欧美福利影院| 国产美女诱惑一区二区| 亚洲电影av| 久久综合图片| 免费看的黄色欧美网站| 日韩五码在线| 韩日成人av| 午夜国产一区| 久久裸体视频| 久久九九电影| 久久精品综合一区| 欧美亚洲视频| 国产精品久久波多野结衣| 亚洲激情婷婷| 国产一区在线免费观看| 欧美日韩另类综合| 欧美久久久久久| 老司机午夜精品视频| 免费久久99精品国产自在现线| 亚洲三级国产| 在线观看一区视频| 在线观看一区| 亚洲美洲欧洲综合国产一区| 亚洲国产一区在线| 亚洲高清毛片| 亚洲免费大片| 国产一区二区三区高清| 国产精品久久久亚洲一区| 国产亚洲在线| 亚洲一区激情| 久久精品首页| 欧美日本中文| 136国产福利精品导航网址| 亚洲欧洲一区二区在线观看| 亚洲精品一区二区三区蜜桃久| 亚洲激情一区| 国产偷自视频区视频一区二区| 一本色道久久综合亚洲精品不卡 | 在线播放亚洲| 亚洲高清网站| 国产日韩欧美一区二区三区在线观看| 亚洲最黄网站| 麻豆av福利av久久av| 欧美在线三区| 亚洲高清在线播放| 亚洲一区二区免费看| 久久久久久9| 亚洲性感美女99在线| 一本一本a久久| 久久婷婷激情| 日韩视频三区| 久久夜色精品| 日韩天天综合| 欧美a级片网站| 一本色道久久综合亚洲精品高清 | 午夜精品久久久久99热蜜桃导演| 欧美一区免费| 亚洲高清资源综合久久精品| 国产精品免费一区二区三区在线观看| 亚洲一级在线| 欧美午夜不卡| 国产精品亚洲欧美| 国产自产在线视频一区| 国产欧美精品久久| 欧美1区2区3区| 亚洲免费播放| 欧美区一区二| 午夜一级在线看亚洲| 在线观看欧美亚洲| 午夜电影亚洲| 免费永久网站黄欧美| 伊人精品视频| 欧美另类专区| 亚洲在线黄色| 一二三区精品| 伊人久久亚洲美女图片| 老司机午夜精品视频| 国产精品日韩欧美一区二区三区| 欧美精品成人| 久久久久一区| 欧美亚洲三级| 亚洲欧美春色| 亚洲在线黄色| 国产精品日韩久久久| 亚洲青涩在线| 在线精品亚洲| 亚洲国产日韩综合一区| 国语精品一区| 欧美日韩免费| 欧美日韩在线一区二区三区| 欧美成人国产| 欧美久久99| 久久精品卡一| 欧美主播一区二区三区美女 久久精品人| 在线播放日韩| 国产精品国产精品| 国内激情久久| 伊人久久亚洲美女图片| 国产主播一区| 尤物在线精品| 中文精品视频| 国产精品永久| 亚洲在线不卡| 久久精品一区二区国产| 老司机精品视频网站| 久久久国产精品一区二区三区| 国产伦理一区| 久久婷婷麻豆| 狠狠色综合网| 国产日韩欧美在线播放不卡| 久久高清国产| 久久资源在线| 国内自拍一区| 国产精品日本| 欧美在线三区| 亚洲黄色影院| 亚洲永久免费| 欧美日韩一区二区三区免费| 在线观看一区视频| 国产九九精品| 欧美日韩精品免费观看视频完整| 在线观看视频日韩| 国产伦精品一区二区三区视频孕妇 | 欧美特黄一级| 激情久久久久| 亚洲欧美久久久久一区二区三区| 久久在线精品| 雨宫琴音一区二区在线| 亚洲欧美日韩另类精品一区二区三区| 老司机午夜精品视频在线观看| 好看的日韩av电影| 亚洲一区日韩| 国精品一区二区| 亚洲一区免费| 影音先锋久久久| 亚洲欧美国产精品桃花| 国产精品分类| 久久aⅴ乱码一区二区三区| 欧美涩涩视频| 性高湖久久久久久久久| 亚洲国产精品日韩| 欧美精品成人| 国产精品一区免费观看| 国产精品红桃| 狂野欧美性猛交xxxx巴西| 亚洲毛片播放| 好吊日精品视频| 久久精品成人一区二区三区蜜臀| 国产一区二区中文字幕免费看| 国产视频在线观看一区| 黄色成人av网站| 欧美伊人久久| 免费看的黄色欧美网站| 99在线精品视频在线观看| 欧美亚韩一区| 欧美日韩免费观看一区| 久久亚洲欧洲| 亚洲在线黄色| 国产九九精品| 国产精品久久久亚洲一区| 亚洲高清视频一区| 亚洲网站在线| 亚洲一级高清| 极品中文字幕一区| 精品999在线观看| 亚洲婷婷在线| 精品成人免费| 伊人成人网在线看| 精品动漫一区| 一区在线电影| 亚洲第一精品影视| 亚洲国产婷婷| 日韩午夜在线电影| 中国成人在线视频| 国产精品一二| 国产模特精品视频久久久久| 一区二区福利| 国产欧美日韩综合精品二区| 亚洲深夜影院| 亚洲欧美日韩国产| 欧美一级播放| 老司机午夜精品视频在线观看| 久久精品系列| 亚洲精品女人| 亚洲黄色影片| 麻豆精品网站| 国产主播精品| 午夜国产精品视频| 欧美一区二区三区在线免费观看| 亚洲欧美国产精品桃花| 鲁鲁狠狠狠7777一区二区| 国产毛片一区| 久热精品在线| 激情成人亚洲| 国产伦精品一区二区三区高清版| 国产农村妇女毛片精品久久莱园子| 国产伦理一区| 午夜精品视频在线观看一区二区| 久久综合久久综合这里只有精品| 欧美日本一区二区高清播放视频| 狠狠综合久久| 国产日本精品| 午夜久久黄色| 夜夜精品视频| 欧美/亚洲一区| 一区在线观看| 亚洲欧美日产图| 欧美日韩亚洲一区二区三区在线| 伊人久久亚洲热| 亚洲欧美久久久久一区二区三区| 欧美成人有码| 国产日韩欧美一区在线| 欧美另类专区| 中文高清一区| 欧美视频二区| 亚洲欧美bt| 亚洲激情女人| 午夜欧美视频| 小嫩嫩精品导航| 亚洲精品日韩久久| 欧美成人综合一区| 99国产精品久久久久久久| 午夜久久久久| 久久xxxx精品视频| 亚洲精品麻豆| 国产一区日韩欧美| 久热精品在线| 欧美亚洲免费在线| 亚洲精品在线二区| 午夜亚洲福利| 久久黄色影院| 午夜在线观看免费一区| 夜久久久久久| 亚洲精品久久久久久一区二区| 午夜精品免费| 久久综合狠狠| 久久经典综合| 香蕉精品999视频一区二区| 亚洲国产精品一区制服丝袜 | 老牛国产精品一区的观看方式| 亚洲人成久久| 一区精品久久| 激情成人亚洲| 亚洲午夜高清视频| 你懂的视频一区二区| 六月丁香综合| 久久精品日产第一区二区| 国产精品日本| 国产农村妇女精品一区二区| 99精品国产在热久久婷婷| 一区在线视频| 亚洲欧洲一区| 在线亚洲精品| 性感少妇一区| 久久久久久婷| 女生裸体视频一区二区三区| 女同性一区二区三区人了人一| 亚洲免费在线| 老司机免费视频久久| 欧美成人免费在线| 欧美日韩免费高清| 一区在线视频| 一本色道久久综合| 亚洲一区二区三区高清不卡| 久久精品中文字幕一区二区三区| 久久久精品动漫| 欧美日韩亚洲一区三区 | 亚洲高清视频一区| 亚洲二区免费| 国产精品外国| 久色成人在线| 亚洲成人中文| 免费日韩av| 国产主播一区二区三区四区| 亚洲精品三级| 久久高清国产| 国内精品久久久久久久影视麻豆 | 欧美一区二区三区四区在线观看地址| 美女久久一区| 一区二区视频欧美| 国产一区成人| 欧美日韩无遮挡| 亚洲麻豆一区| 久久久久欧美| 亚洲二区视频| 久久精品女人天堂| 在线观看亚洲| 久久久久久9| 在线成人亚洲| 六月婷婷一区| 亚洲第一在线| 欧美成人一品| 一本一本久久a久久精品综合妖精| 米奇777在线欧美播放| 欧美视频四区| 亚洲一区二区三区高清不卡| 国内揄拍国内精品久久| 欧美亚洲在线| 亚洲福利av| 久久午夜精品| 亚洲一区二区三区免费观看| 激情国产一区| 欧美精品色网| 久久久久久久久久久一区| 亚洲欧洲午夜| 国产专区一区| 欧美国产日本| 久久先锋资源| 亚欧美中日韩视频| 国产精品久久久久久久久婷婷| 亚洲无线视频| 午夜精品视频| 老司机精品久久| 亚洲一区二区动漫| 国产精品久久久一区二区三区| 亚洲高清自拍| 精品999日本| 激情亚洲成人| 极品中文字幕一区| 激情文学一区| 在线看无码的免费网站| 亚洲一二三区在线| 亚洲无线一线二线三线区别av| 老牛影视一区二区三区| 久久综合导航| 欧美 日韩 国产精品免费观看| 噜噜噜久久亚洲精品国产品小说| 亚洲制服av| 免费欧美日韩| 牛夜精品久久久久久久99黑人| 久久性天堂网| 午夜精品一区二区三区四区 | 久久尤物视频| 欧美在线三区| 欧美激情视频一区二区三区在线播放 | 国产视频亚洲| 亚洲综合国产激情另类一区| 久久国产66| 欧美日本三区| 亚洲精品1区2区| 国产免费成人| 亚洲欧美影院| 亚洲国产一区二区三区在线播| 亚洲精品社区| 国产免费成人| 欧美黄色一区二区| 欧美午夜不卡| 一区二区三区国产在线| 亚洲欧美日韩国产综合精品二区| 久久精品二区| 亚洲午夜激情| 先锋影音国产一区| 欧美一区三区二区在线观看| 国语自产精品视频在线看8查询8| 最新亚洲视频| 久久久夜夜夜| 激情婷婷久久| 免费在线欧美黄色| 亚洲天堂男人| 性久久久久久| 国产精品hd| 国产精品日韩| 狠狠色综合网站久久久久久久| 99视频精品免费观看| 久久久久看片| 亚洲黄色高清| 欧美人成在线| 国产毛片久久| 亚洲国产一区二区三区在线播| 久久激情一区| 亚洲乱亚洲高清| 久久久久久一区二区| 99re热精品| 国产精品草草| 久久久综合香蕉尹人综合网| 在线视频精品| 激情丁香综合| 欧美黄在线观看| 老鸭窝91久久精品色噜噜导演|