怎么解决数据库LOB字段带来的性能影响
发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,这篇文章主要讲解了"怎么解决数据库LOB字段带来的性能影响",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"怎么解决数据库LOB字段带来的性能影响"吧!今
千家信息网最后更新 2025年01月23日怎么解决数据库LOB字段带来的性能影响
这篇文章主要讲解了"怎么解决数据库LOB字段带来的性能影响",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"怎么解决数据库LOB字段带来的性能影响"吧!
今天开发人员反映一个SQL查询时间大概2-3分钟:
SELECT * FROM (SELECT ROWNUM AS ROWNUMBER__, T.* FROM (Select T1.CONSULTINGCODE AS "ConsultingCode", T1.CATEGORY AS "Category", T1.CUSCODE AS "CusCode", T1.ORDERCODE AS "OrderCode", T1.WARECODE AS "WareCode", DECRYPTBYKEY(T1.MOBILEPHONE) AS "MobilePhone", DECRYPTBYKEY(T1.EMAILENCRYPT) AS "EmailEncrypt", T1.ASSIGNTIME AS "AssignTime", T1.REPLIER AS "Replier", T1.REPLYCODE AS "ReplyCode", T1.REPLYDATE AS "ReplyDate", T1.BYWAY AS "ByWay", T1.CREATETIME AS "CreateTime", T1.EVALUATE AS "Evaluate", T1.EXPIREMAN AS "ExpireMan", T1.EXPIREREASON AS "ExpireReason", T1.CONSULTINGTYPEID AS "ConsultingTypeID", T1.STATUS AS "Status", T1.QUESTION AS "Question", T1.MAILCONTENTS AS "MailContents", T1.REPLYCONTENT AS "ReplyContent", T1.ENCEMAIL AS "EncEmail" From mbs7_crm.KH_Consulting T1 left Join mbs7_crm.KH_Customer T2 on T1.CUSCODE = T2.CUSCODE ORDER BY T1.STATUS ASC, T1.CREATETIME ASC) T WHERE "CreateTime" >= date '2013-9-1' AND "ReplyCode" IN ('128') AND "CreateTime" <= timestamp '2013-9-30 23:59:59' AND ROWNUM <= 10000) TEMP WHERE ROWNUMBER__ > 0
分析:
该语句从执行计划来看,走了时间索引,返回记录是1千多,如果全部查询出来进度很慢(分页的翻页操作很慢),后来发现该语句的性能主要是消耗在:字段"Question","MailContents","Category"和"ReplyContent"上,把这4个字段注释小,查询时间在5s内,后来发现这4个字段为CLOB字段类型,因为CLOB字段这种字段类型的存储方式是比较复杂的,如果该CLOB字段内容超出一定值,会用指针指向另一个SEGMENT,把内容存放在新的SEGMENT; 这样当访问的时候,会出现IO次数增加,从而影响性能,并且CLOB类型有独立的回滚机制,当一致性读的行数较多时,响应时间很慢,而就算存储的内容较小,CLOB本身也会调用系统内部的函数进行匹配和寻址,也是很消耗CPU时间的.
解决方案:
经与开发人员沟通,该表的此四个字段其实实际存储内容远没有超出4000个字节(varchar2的最大长度),当初设计的时候没有考虑精准,于是计划把这些字段类型按照下列方法重新调整:
alter table mbs7_crm.KH_Consulting add (QUESTION2 varchar2(2000));update mbs7_crm.KH_Consulting set QUESTION2=dbms_lob.substr(QUESTION,4000);alter table mbs7_crm.KH_Consulting drop column QUESTION;alter table mbs7_crm.KH_Consulting rename column QUESTION2 to QUESTION;
修改后,重新查询,在5S内。
感谢各位的阅读,以上就是"怎么解决数据库LOB字段带来的性能影响"的内容了,经过本文的学习后,相信大家对怎么解决数据库LOB字段带来的性能影响这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
字段
性能
内容
影响
时间
数据
数据库
类型
查询
存储
学习
人员
时候
语句
开发
消耗
复杂
精准
一致
一致性
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
手机软件开发程序代码
我国网络安全的手抄报
韶关机器人rpa软件开发
深圳市丰巢网络技术有限
数据库标准模定义
ftp服务器 新增用户
网络安全技术高峰论坛致辞
腾讯云香港服务器防护
国网全场景网络安全防护架构
计算机网络技术高考必选科目
小振服务器
央企服务器不能租
厦门东塔网络安全特训营包住宿
江苏赛迪网络技术有限公司
服务器被黑客入侵的经历
五年级网络安全知识演讲比赛
手游怎样启动服务器
cs软件开发用什么语言
软件开发行业属于工业吗
杭州管理软件开发如何收费
辽宁正规软件开发服务有哪些
网络安全体系 层层落实
安卓手机做samba服务器
软件开发服务和销售软件怎么区分
互联网电话服务器
软件开发退税财务处理
互联网络科技有限责任公司
js留言到数据库
软件开发技术报告书
cod17为什么连接不到服务器