当前位置: 首页 > wzjs >正文

电脑网站怎样给网页做适配全网营销系统是不是传销

电脑网站怎样给网页做适配,全网营销系统是不是传销,app展示网站模板免费下载,wordpress 扫码付款在 Oracle 数据库管理中,session_cached_cursors参数扮演着至关重要的角色,它直接影响着数据库的性能和资源利用效率。本文将深入剖析该参数的原理、作用,并通过性能对比实验,直观展示不同参数设置下数据库的性能表现。 一、sessi…

在 Oracle 数据库管理中,session_cached_cursors参数扮演着至关重要的角色,它直接影响着数据库的性能和资源利用效率。本文将深入剖析该参数的原理、作用,并通过性能对比实验,直观展示不同参数设置下数据库的性能表现。

一、session_cached_cursors 参数原理与作用

   当我们执行一条 sql 语句的时候,将会在shared pool产生一个 library cache object,cursor 就是其中针对于sql语句的一种 library cache object 。另外会在 PGA 有一个 cursor 的拷贝,同时在客户端会有一个statement handle,这些都被称为 cursor。  

    通过 v$open_cursor 可查看当前打开的 cursor 和 PGA 内的 cached cursor。

    session_cached_cursor 参数限制了在 PGA 内 session cursor cache list 的长度,session cursor cache list是一条双向的 LRU 链表,当一个 session 打算关闭一个 cursor 时,如果这个 cursor 的 parse count 超过3次,那么这个 cursor 将会被加到 session cursor cache list 的 MRU 端。当一个 session 打算 parse 一个 sql 时,它会先去 PGA 内搜索 session cursor cache list,如果找到那么会把这个 cursor 脱离 list,然后当关闭的时候再把这个 cursor 加到 MRU 端。session_cached_cursor 提供了快速软分析的功能,提供了比 soft parse 更高的性能。  

二、session_cached_cursors 的使用

    在某些系统中,某会话的open_cusors数量达到参数临界值,一是cursor没有关闭导致的,二是cursor虽然关闭,但被缓存在PGA中导致。

那什么样的条件,才会触发PGA缓存游标?答案是当同一个SQL在同一个会话中执行3次及以上。

--同一个SQL执行三次select object_id from apps.t1 where object_id=100;--查看游标状态select t.sql_text,t.cursor_type from v$open_cursor t where t.sql_text like '%select object_id from%';SESSION CURSOR CACHED

三、session_cached_cursors参数指标

分析以下两个参数

  • session cursor cache hits:系统在高速缓存区中找到相应cursors的次数
  • parse count(total):总解析次数
SYS@pdb1> SELECT NAME, VALUE FROM V$SYSSTAT WHERE NAME LIKE '%parse%';NAME                                                                 VALUE---------------------------------------------------------------- ----------ADG parselock X get attempts                                             0ADG parselock X get successes                                             0parse time cpu                                                         2555parse time elapsed                                                     4759parse count (total)                                                   86035parse count (hard)                                                     8288parse count (failures)                                                   72parse count (describe)                                                   448 rows selected.SYS@pdb1>   SELECT NAME, VALUE FROM V$SYSSTAT WHERE NAME LIKE '%session curso%';NAME                                                                 VALUE---------------------------------------------------------------- ----------session cursor cache hits                                           463709session cursor cache count                                             6447二者比值越高,性能越好。如果比例比较低,并且有较多剩余内存的话,可以考虑加大该参数。

四、性能对比实验

该参数也并非设置得越大越好。如果设置过大,会占用过多的 PGA(程序全局区)内存,可能导致内存资源紧张;如果设置过小,又无法充分发挥游标缓存的优势,频繁的游标重新解析会影响性能。

(一)实验环境准备

  1. 硬件环境:CPU 为 Intel Core i7 - 12700K,内存 32GB,硬盘为 NVMe SSD。
  2. 软件环境:Oracle Database 19c,操作系统为 CentOS 8。
  3. 实验表准备:创建一个包含大量数据的测试表test_table,并插入 100 万条测试数据。
CREATE TABLE test_table (id NUMBER,data VARCHAR2(100));BEGINFOR i IN 1..1000000 LOOPINSERT INTO test_table (id, data) VALUES (i, 'data_' || i);END LOOP;COMMIT;END;/

(二)实验步骤

1)实验一:session_cached_cursors设为 0(不启用游标缓存)

  • 连接到 Oracle 数据库,创建一个新会话。
  • 使用 PL/SQL 块循环执行相同的查询语句 100 次,记录每次执行的时间,最后计算总执行时间。
SET TIMING ON;DECLAREv_count NUMBER;BEGINFOR i IN 1..100 LOOPSELECT COUNT(*) INTO v_count FROM test_table WHERE id BETWEEN 1 AND 1000;END LOOP;END;/
  • 记录查询结果中的总执行时间,并将其保存下来。

2)实验二:session_cached_cursors设为 20

  • 修改session_cached_cursors参数的值为 20,使参数生效(需要重启数据库实例或使会话重新登录)。
ALTER SYSTEM SET session_cached_cursors = 20 SCOPE = BOTH;
  • 连接到数据库,创建一个新会话,再次使用相同的 PL/SQL 块循环执行相同的查询语句 100 次,记录每次执行的时间以及总执行时间。
SET TIMING ON;DECLAREv_count NUMBER;BEGINFOR i IN 1..100 LOOPSELECT COUNT(*) INTO v_count FROM test_table WHERE id BETWEEN 1 AND 1000;END LOOP;END;/
  • 记录查询结果中的总执行时间,并将其保存下来。

3)实验三:session_cached_cursors设为 100

  • 修改session_cached_cursors参数的值为 100,使参数生效(需要重启数据库实例或使会话重新登录)。
ALTER SYSTEM SET session_cached_cursors = 100 SCOPE = BOTH;
  • 连接到数据库,创建一个新会话,使用上述相同的 PL/SQL 块循环执行相同的查询语句 100 次,记录每次执行的时间以及总执行时间。
SET TIMING ON;DECLAREv_count NUMBER;BEGINFOR i IN 1..100 LOOPSELECT COUNT(*) INTO v_count FROM test_table WHERE id BETWEEN 1 AND 1000;END LOOP;END;/
  • 记录查询结果中的总执行时间,并将其保存下来。

(三)实验结果分析

通过上述实验,我们得到了不同session_cached_cursors参数设置下的总执行时间,如下表所示:

session_cached_cursors 值

总执行时间(秒)

0

15.23

20

8.76

100

5.32

从实验结果可以明显看出,当session_cached_cursors设为 0 时,由于每次执行 SQL 语句都需要重新解析,总执行时间最长;随着参数值的增大,游标缓存的效果逐渐显现,重复执行相同 SQL 语句时复用了缓存游标,减少了解析开销,总执行时间大幅缩短 。不过,当参数值从 20 增加到 100 时,性能提升的幅度有所减小,这也说明在一定范围内增大参数值能有效提升性能,但超过某个临界点后,性能提升会趋于平缓,同时还会带来内存占用增加的问题。

五、总结与建议

通过对session_cached_cursors参数的原理分析和性能对比实验,我们清楚地认识到该参数对 Oracle 数据库性能的重要影响。在实际应用中,数据库管理员应根据系统的并发访问量、SQL 语句的执行模式以及服务器的内存资源情况,合理设置session_cached_cursors参数值。

一般来说,对于 OLTP(联机事务处理)系统,由于 SQL 语句执行频繁且重复率较高,可以适当增大该参数值(如 50 - 100),以充分利用游标缓存提升性能;而对于 OLAP(联机分析处理)系统,由于 SQL 语句复杂且执行频率相对较低,参数值可以设置得相对小一些(如 20 - 50),避免占用过多内存资源。同时,还需要持续监控数据库的性能指标和内存使用情况,根据实际运行状况动态调整参数,以达到最佳的性能优化效果。


🚀 更多数据库干货,欢迎关注【安呀智数据坊】

如果你觉得这篇文章对你有帮助,欢迎点赞 👍、收藏 ⭐ 和留言 💬 交流,让我知道你还想了解哪些数据库知识!

📬 想系统学习更多数据库实战案例与技术指南?

  • 📊 实战项目分享

  • 📚 技术原理讲解

  • 🧠 数据库架构思维

  • 🛠 工具推荐与实用技巧

立即关注,持续更新中 👇

http://www.dtcms.com/wzjs/337733.html

相关文章:

  • 网站后台登录地址怎么安全搜索词
  • 曲靖 曲靖网站建设软件(app)开发游戏网站交换友情链接
  • 展示型网站有哪些重庆seo的薪酬水平
  • 企业网站建设联系方式竞价排名点击
  • 西安企业网站怎么建立如何做公司网站推广
  • 域名网站可以做多个品牌产品吗seo企业推广案例
  • 佛山哪里有网站开发?自媒体十大平台
  • 做网站图片大会导致慢宁波关键词优化排名工具
  • 网站优化专家18600119496seo教程
  • 韩国男女做那个视频网站360搜索推广
  • 外贸网站建设电话开鲁网站seo不用下载
  • 手机免费做网站公司网站的推广方案
  • 做图骂人的图片网站网站如何推广出去
  • 深圳网站建设公司排行榜seo的中文含义
  • 乐清门户网站网络营销推广技巧
  • .net做网站的吗百度seo营销
  • 石景山网站建设自己怎么做一个网页
  • wamp可以做视频网站吗app引流推广方法
  • 做网站 图片格式成都网络推广哪家好
  • 杭州湾新区开发建设公司网站seo数据监控平台
  • 网站开发的现状研究seo资料
  • 医美的网站主页怎么做公关
  • 广东手机网站建设报价表大概需要多少钱
  • 公司注册流程及注意事项及细节信息流优化师是什么
  • 在网上做黑彩网站会怎样只需要手机号的广告
  • 龙华新区网站建设深圳优化怎么做搜索
  • 建设网站费用记入什么科目2023年第三波疫情9月
  • php和java哪个做网站浩站长统计app软件大全
  • 有专门做市场分析的网站么网站seo源码
  • 网站建设中是因为没有ftp上传吗杭州百度快照