SQL优化案例-自定义函数索引(五)
发表于:2024-11-23 作者:千家信息网编辑
千家信息网最后更新 2024年11月23日,SQL 文本如下,表本身很小,走全表扫描也很快,但因业务重要性,要求尽可能缩短查询时间(为保证客户隐私,已经将注释和文字部分去掉):SELECT MERCHCODE AS R_MERCHCODE,
千家信息网最后更新 2024年11月23日SQL优化案例-自定义函数索引(五)
SQL 文本如下,表本身很小,走全表扫描也很快,但因业务重要性,要求尽可能缩短查询时间(为保证客户隐私,已经将注释和文字部分去掉):
SELECT MERCHCODE AS R_MERCHCODE, TRANDATE, TRANTIME, TRANTYPE AS TRANSTYPE, TRACENO, POSID AS R_POSID, ACCOUNT AS R_CARDNO, AMT, FEE, NVL(RESERVED1,'N') BORDERCARDBUSIFLAG, CASE WHEN I.BANCSRETFLAG='0000' THEN '1' WHEN I.BANCSRETFLAG='9999' THEN'0' ELSE '2' END AS RETURNCODEFROM IC_MERCHTRANSDETAIL_428 IWHERE GETACCTNO(ACTSTLACCTNO)=GETACCTNO('14250000000454865') AND ROWNUM < 500;
执行计划如下:
可以看到谓词信息是客户号,可以确定此列选择性非常高,非常适合建立索引。
CREATE INDEX IDX_GETACCTNO ON IC_MERCHTRANSDETAIL_428 (GETACCTNO(ACTSTLACCTNO)) PARALLEL 10 TABLESPACE REPT *ERROR at line 1:ORA-30553: The function is not deterministic
确定函数本身不会受到不确定值的影响,创建函数索引。
加上 deterministic 并且取别名,查看函数创建语句:
CREATE OR REPLACE FUNCTION GETACCTNOCY (acct varchar2) return varchar2 DETERMINISTICistmpacct varchar2(40);st_res varchar2(40); --st_res:=tmpacctbegintmpacct:='';st_res :='';IF (length(trim(acct))=16) THENBEGIN SELECT ACCOUNT INTO tmpacct FROM LINK_L WHERE LINK_L.CARD=LPAD(trim(acct),20,0) AND ISO_TYPE='1' AND CATEGORY='0';EXCEPTION WHEN NO_DATA_FOUND THEN tmpacct:=TRIM(ACCT);END;END IF;IF(length(trim(acct))>17) THEN BEGIN SELECT zh INTO tmpacct FROM load_zhmap WHERE jzh=trim(acct); EXCEPTION WHEN NO_DATA_FOUND THEN tmpacct:=''; END;END IF; IF(length(trim(acct))=17) THEN tmpacct:=substr(acct,1,16); END IF;st_res:=tmpacct;return st_res;EXCEPTIONWHEN OTHERS THENreturn '';END;
创建索引:
CREATE INDEX IDX_GETACCTNO ON IC_MERCHTRANSDETAIL_428 (GETACCTNOCY(ACTSTLACCTNO)) TABLESPACE TBSIDX;
创建索引后的执行计划如下:
案例较为简单,希望可以帮助到大家。
| 作者简介
姚崇·沃趣科技高级数据库技术专家
熟悉Oracle数据库内部机制,丰富的数据库及RAC集群层故障诊断、性能调优、OWI、数据库备份恢复及迁移经验。
索引
数据
数据库
函数
客户
案例
重要
高级
专家
业务
作者
信息
别名
备份
尽可能
很快
性能
技术
故障
文字
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
mysql生成数据库模型
网络安全投资主线
网络安全 三要素aaa
什么情况下警察查数据库
金融网络安全管理论文
打造家庭服务器
计算机和服务器市场
软件开发面经
冀时办数据库操作失败怎么回事
杨浦区创新软件开发厂家价格对比
龙岗网络安全运维怎么样
服务器怎么配置二级域名
nat代理服务器
上海军方网络安全会议
山西商场大屏触摸软件开发公司
天津会计软件开发中心
湖州java软件开发项目
分组后求和 数据库
中国网络安全的三个阶段
深圳手机app软件开发
网络安全靠人民活动
学费分期软件开发
怎么画网络安全的画图片
幼儿园网络安全管理工作方案
万稷网络技术有限公司
滨州联想服务器零售商
mysql创建数据库成功
湖州java软件开发项目
思科服务器管理ip
修照片软件开发