freepeople性欧美熟妇, 色戒完整版无删减158分钟hd, 无码精品国产vα在线观看DVD, 丰满少妇伦精品无码专区在线观看,艾栗栗与纹身男宾馆3p50分钟,国产AV片在线观看,黑人与美女高潮,18岁女RAPPERDISSSUBS,国产手机在机看影片

正文內(nèi)容

優(yōu)化sql語句提高oracle執(zhí)行效率-在線瀏覽

2025-08-11 17:17本頁面
  

【正文】 這個字段的值是不確
定的,根據(jù)上篇寫的工作流程,where的作用時間是在計算之前就完成的,而having就是在計算后才起作用的,所以在這種情況下,
兩者的結(jié)果會不同。系統(tǒng)首先根據(jù)各個表之間的聯(lián)接條件,把多個表合成一個臨時表后
,再由where進行過濾,然后再計算,計算完后再由having進行過濾。 2009729 09:49 回復(fù) 視學(xué)中國6位粉絲2樓(12)減少對表的查詢: 在含有子查詢的SQL語句中,要特別注意減少對表的查詢。能夠掌握上面的運用函數(shù)解決問題的方法在實際工作中是非常有意義的。這樣一來,就可以減少解析的時間并減少那些由Column
歧義引起的語法錯誤。在這種情況下, 使用EXISTS(或NOT EXISTS)通常將提
高查詢的效率。無論在哪種情況下,NOT IN都是最低效的 (因為它對子查詢中
的表執(zhí)行了一個全表遍歷)。 例子: (高效)SELECT * FROM EMP (基礎(chǔ)表) WHERE EMPNO 0 AND EXISTS (SELECT ‘X39。) (低效)SELECT * FROM EMP (基礎(chǔ)表) WHERE EMPNO 0 AND DEPTNO IN(SELECT DEPTNO FROM DEPT WHERE LOC = ‘MELB39。 (17)用索引提高效率: 索引是表的一個概念部分,用來提高檢索數(shù)據(jù)的效率,Oracle使用了一個復(fù)雜的自平衡Btree結(jié)構(gòu)。當(dāng)Oracle找出執(zhí)行查詢和Update語句的最佳路徑時, Oracle優(yōu)化器將使用索引。另一個使用索引的好處是,它提供了主鍵(primary key)的唯一性驗證。通常, 在大型表中使用索引特別有效. 當(dāng)然,你也會發(fā)現(xiàn), 在掃描小表時,使用索引同樣能提高效率。索引需要空間來存儲,也需要定期維護, 每當(dāng)有記錄在表中增減或索引列被修改時, 索
引本身也會被修改。因為索引需要額外的存儲空間
和處理,那些不必要的索引反而會使查詢反應(yīng)時間變慢。一般可以考慮用EXIST替換,
EXISTS 使查詢更為迅速,因為RDBMS核心模塊將在子查詢的條件一旦滿足后,立刻返回結(jié)果。 FROM EMP E WHERE = )。 (20)在Java代碼中盡量少用連接符“+”連接字符串。當(dāng)Oracle“
遇到”NOT,他就會停止使用索引轉(zhuǎn)而執(zhí)行全表掃描。WHERE子句中,如果索引列是函數(shù)的一部分。 舉例: 低效: SELECT … FROM DEPT WHERE SAL * 12 25000。 (23)用=替代: 高效: SELECT * FROM EMP WHERE DEPTNO =4 低效: SELECT * FROM EMP WHERE DEPTNO 3 兩者的區(qū)別在于, 前者DBMS將直接跳到第一個DEPT等于4的記錄而后者將首先定位到DEPTNO=3的記錄并且向前掃描到第一個DEPT大于3
的記錄。對索引列使用OR將造成全表掃描。在下面的例子中, LOC_ID 和REGION上都建有索引。 (26)避免在索引列上使用IS NULL和IS NOT NULL: 避免在索引中使用任何可以為空的列,Oracle將無法使用該索引。對于復(fù)
合索引,如果每個列都為空,索引中同樣不存在此記錄. 如果至少有一個列不為空,則記錄存在于索引中。 然而如果所有的索引列都為空,Oracle將認為整個鍵值為空而空不等于空。 2009729 09:49 回復(fù) 視學(xué)中國6位粉絲4樓低效: (索引失效) SELECT … FROM DEPARTMENT WHERE DEPT_CODE IS NOT NULL。 (27)總是使用索引的第一個列: 如果索引是建立在多個列上, 只有在它的第一個列(lea
點擊復(fù)制文檔內(nèi)容
范文總結(jié)相關(guān)推薦
文庫吧 www.dybbs8.com
備案圖鄂ICP備17016276號-1