SQL优化案例-自定义函数索引(五)
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,SQL 文本如下,表本身很小,走全表扫描也很快,但因业务重要性,要求尽可能缩短查询时间(为保证客户隐私,已经将注释和文字部分去掉):SELECT MERCHCODE AS R_MERCHCODE,
千家信息网最后更新 2025年11月07日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安全错误
数据库的锁怎样保障安全
数据库硬件代理商利润
怎么设计网络安全论文
联网技术人员网络安全知识答案
软件开发怎么运作
数据库中的自助存取
网络安全该怎样学
有关网络安全问题的作文
qq空间留言时服务器繁忙
网络安全活动通知稿
浙江移动大带宽服务器虚拟主机
内部服务器网站搭建
电子支付极其网络安全研究
公司云服务器租用费用
河北网络安全知识问答
计算机网络技术辅导班
鸿巨网络技术有限公司
数据库技术 实验指导
湖北医院医疗系统软件开发
网页数据库 源码
数据库是否需要添加主键
局网络安全工作应急演练方案
宜昌我来网络技术有限公司
检查网络安全
基本网络安全策略
村居开展网络安全宣传活动
山西网络安全管理处
阿里云服务器是真实主机吗
零基础学计算机网络技术
临沂阿帕网络技术公司
数据库字段级比较