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

首頁 > 開發(fā) > 綜合 > 正文

如何正確的使用or展開來改寫SQL查詢

2024-07-21 02:42:16
字體:
供稿:網(wǎng)友
問題:

下面的這條sql應(yīng)該怎么優(yōu)化?

select * from sys_user where user_code = 'zhangyong' or user_code in (select grp_code from sys_grp where sys_grp.user_code = 'zhangyong')Execution Plan----------------------------------------------------------0  SELECT STATEMENT Optimizer=RULE1  0   FILTER2  1     TABLE access (FULL) OF 'SYS_USER'3  1     INDEX (UNIQUE SCAN) OF 'PK_SYS_GRP' (UNIQUE)Statistics----------------------------------------------------------14  recursive calls4  db block gets30590 consistent gets0  physical reads0  redo size1723  bytes sent via SQL*Net to client425  bytes received via SQL*Net from client2  SQL*Net roundtrips to/from client0  sorts (memory)0  sorts (disk)3  rows PRocessed

里面的查詢返回的記錄數(shù)一般只有一兩條,但sys_user表的數(shù)據(jù)很多,怎么樣才能讓這條sql以sys_grp為驅(qū)動表?

表中記錄情況如下:

SQL> select count(*) from sys_grp;COUNT(*)----------25130SQL> select count(*) from sys_user;COUNT(*)----------15190

優(yōu)化:

降低邏輯讀是優(yōu)化SQL的基本原則之一

我們嘗試通過降低邏輯讀來加快SQL的執(zhí)行.

這里我們使用or展開來改寫SQL查詢:

select * from sys_user where user_code = 'zhangyong' union allselect * from sys_user where user_code <> 'zhangyong' and user_code in (select grp_code from sys_grp where sys_grp.user_code = 'zhangyong')Statistics----------------------------------------------------------          0  recursive calls          0  db block gets         130 consistent gets          0  physical reads          0  redo size       1723  bytes sent via SQL*Net to client        425  bytes received via SQL*Net from client          2  SQL*Net roundtrips to/from client          1  sorts (memory)          0  sorts (disk)          3  rows processedExecution Plan----------------------------------------------------------0      SELECT STATEMENT Optimizer=RULE1    0   UNION-ALL2    1     TABLE ACCESS (BY INDEX ROWID) OF 'SYS_USER'3    2       INDEX (UNIQUE SCAN) OF 'PK_SYS_USER' (UNIQUE)4    1     NESTED LOOPS5    4       VIEW OF 'VW_NSO_1'6    5         SORT (UNIQUE)7    6           TABLE ACCESS (BY INDEX ROWID) OF 'SYS_GRP'8    7             INDEX (RANGE SCAN) OF 'FK_SYS_USER_CODE' (NON-UNIQUE)9    4       TABLE ACCESS (BY INDEX ROWID) OF 'SYS_USER'10    9         INDEX (UNIQUE SCAN) OF 'PK_SYS_USER' (UNIQUE)

我們注意到,通過改寫,邏輯讀減少到130,從30590到130這是一個巨大的提高,減少邏輯讀最終會減少資源消耗,提高SQL的執(zhí)行效率.

這個改寫把Filter改為了Nest LOOP,索引得以充分利用.從而大大提高了性能.

我們同時注意到,這里引入了一個排序

排序來自于這一步:

----------------------------------6  5  SORT (UNIQUE)7  6    TABLE ACCESS (BY INDEX ROWID) OF 'SYS_GRP'8  7   INDEX (RANGE SCAN) OF 'FK_SYS_USER_CODE' (NON-UNIQUE)----------------------------------

注釋:在'SYS_GRP'表中,user_code 是非唯一鍵值,在in值判斷里,要做sort unique排序,去除重復(fù)值,這里的union all是不需要排序的。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 天峻县| 庄浪县| 抚顺县| 南皮县| 平和县| 应城市| 保康县| 广德县| 喀喇沁旗| 高台县| 凤阳县| 罗江县| 禄丰县| 拉萨市| 连平县| 通化市| 宿州市| 阜城县| 鹤山市| 安宁市| 长乐市| 禄劝| 宁强县| 东兰县| 荃湾区| 孟津县| 富蕴县| 屯留县| 临邑县| 宝兴县| 沙湾县| 神池县| 丰镇市| 通辽市| 石河子市| 凤山县| 台湾省| 阿拉善右旗| 全椒县| 珠海市| 广河县|