国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > SQL Server > 正文

解讀SQL的select語(yǔ)句執(zhí)行順序

2024-08-31 00:46:45
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
一、sql語(yǔ)句的執(zhí)行步驟:
 1)語(yǔ)法分析,分析語(yǔ)句的語(yǔ)法是否符合規(guī)范,衡量語(yǔ)句中各表達(dá)式的意義。
2) 語(yǔ)義分析,檢查語(yǔ)句中涉及的所有數(shù)據(jù)庫(kù)對(duì)象是否存在,且用戶有相應(yīng)的權(quán)限。
3)視圖轉(zhuǎn)換,將涉及視圖的查詢語(yǔ)句轉(zhuǎn)換為相應(yīng)的對(duì)基表查詢語(yǔ)句。
4)表達(dá)式轉(zhuǎn)換, 將復(fù)雜的 SQL 表達(dá)式轉(zhuǎn)換為較簡(jiǎn)單的等效連接表達(dá)式。
 5)選擇優(yōu)化器,不同的優(yōu)化器一般產(chǎn)生不同的“執(zhí)行計(jì)劃”
6)選擇連接方式, ORACLE 有三種連接方式,對(duì)多表連接 ORACLE 可選擇適當(dāng)?shù)倪B接方式。
7)選擇連接順序, 對(duì)多表連接 ORACLE 選擇哪一對(duì)表先連接,選擇這兩表中哪個(gè)表做為源數(shù)據(jù)表。
8)選擇數(shù)據(jù)的搜索路徑,根據(jù)以上條件選擇合適的數(shù)據(jù)搜索路徑,如是選用全表搜索還是利用索引或是其他的方式。
9)運(yùn)行“執(zhí)行計(jì)劃”
二、oracle 共享原理:
ORACLE將執(zhí)行過(guò)的SQL語(yǔ)句存放在內(nèi)存的共享池(shared buffer pool)中,可以被所有的數(shù)據(jù)庫(kù)用戶共享 當(dāng)你執(zhí)行一個(gè)SQL語(yǔ)句(有時(shí)被稱為一個(gè)游標(biāo))時(shí),如果它和之前的執(zhí)行過(guò)的語(yǔ)句完全相同, ORACLE就能很快獲得已經(jīng)被解析的語(yǔ)句以及最好的 執(zhí)行路徑. 這個(gè)功能大大地提高了SQL的執(zhí)行性能并節(jié)省了內(nèi)存的使用
三、oracle 語(yǔ)句提高查詢效率的方法:
1: where column in(select * from ... where ...); 2:... where exists (select 'X' from ...where ...); 第二種格式要遠(yuǎn)比第一種格式的效率高。在Oracle中可以幾乎將所有的IN操作符子查詢改寫為使用EXISTS的子查詢 使用EXIST,Oracle系統(tǒng)會(huì)首先檢查主查詢,然后運(yùn)行子查詢直到它找到第一個(gè)匹配項(xiàng),這就節(jié)省了時(shí)間 Oracle系統(tǒng)在執(zhí)行IN子查詢時(shí),首先執(zhí)行子查詢,并將獲得的結(jié)果列表存放在在一個(gè)加了索引的臨時(shí)表中 避免使用having字句 避免使用HAVING子句, HAVING 只會(huì)在檢索出所有記錄之后才對(duì)結(jié)果集進(jìn)行過(guò)濾. 這個(gè)處理需要排序,總計(jì)等操作. 如果能通過(guò)WHERE子句限制記錄的數(shù)目,那就能減少這方面的開銷

SQL Select語(yǔ)句完整的執(zhí)行順序: 

1、from子句組裝來(lái)自不同數(shù)據(jù)源的數(shù)據(jù);
 2、where子句基于指定的條件對(duì)記錄行進(jìn)行篩選;
3、group by子句將數(shù)據(jù)劃分為多個(gè)分組;
4、使用聚集函數(shù)進(jìn)行計(jì)算;
5、使用having子句篩選分組;
6、計(jì)算所有的表達(dá)式;
7、使用order by對(duì)結(jié)果集進(jìn)行排序。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 桐乡市| 山东省| 安仁县| 扶绥县| 郁南县| 峨边| 西乡县| 个旧市| 白银市| 安溪县| 根河市| 鹿邑县| 巩留县| 专栏| 溆浦县| 望奎县| 黄大仙区| 南部县| 岑巩县| 万全县| 商丘市| 革吉县| 武乡县| 博野县| 安仁县| 德庆县| 凤阳县| 肇东市| 喀喇沁旗| 固原市| 周至县| 施甸县| 洞口县| 新沂市| 安达市| 铁力市| 襄樊市| 自贡市| 冷水江市| 开平市| 德惠市|