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

oracle-sql语句解析类型

语句执行过程:1. 解析(将sql解析成执行计划) 2.执行 3.获取数据(fetch)

1. shared pool的组成。

share pool是一块内存池。
主要分成3块空间。free, library(库缓存,缓存sql以及执行计划),row cache(字典缓存)

select * from v$sgastat a where NAME = 'library cache';
select * from v$sgastat a where NAME = 'shared pool' and a.NAME = 'free memory';
select * from v$sgastat a where a.NAME = 'row cache';

硬解析(hard parse), 软解析(soft parse)。 都要频繁的访问数据字典信息。
从一个sql语句的n种执行方案中挑选出最优的执行方案作为执行计划。

软硬解析具体情况。

select name,value from v$sysstat a where a.NAME like 'parse%';

shared pool内存块组成。

free空间。

chain,chunk

free空间有很多chain(链条), 链上挂着空闲的块,不同的链条挂的块的大小不一样。
在这里插入图片描述

用锁(latch)保护chain(链条)

ora-4031错误。
原因一:大量的硬解析
原因二:小碎片,又突然来了大的sql语句,需要大的内存空间。

library cache

也是用链管理chunk。这里的链用的不是chunk的大小来管理chunk。而是将sql翻译成ascii,用ascii对应的数字计算出sql在哪个链条上。
在这里插入图片描述

select count(*) from x$ksmsp;  -- shared pool的总的chunk数alter system flush shared_pool;  -- 将shared pool的library cache和row cache的内容清空。

sql共享

sql共享可以减少硬解析。
使用绑定变量来实现共享sql。

sql语句组成部分。静态部分,动态部分。

select executions, a.* from v$sql a;

两个sql完全一样,才会共享。


spool 1.lst  -- 会将下面sql查询的结果放到1.lst文件中。
-- 没有共享sql的语句。   executions = 1表示执行1次的sql.
select SQL_FULLTEXT from v$sql a where executions = 1 order by sql_text;spool off
exit

在这里插入图片描述

http://www.lryc.cn/news/227570.html

相关文章:

  • 2023 年最新企业微信官方会话机器人开发详细教程(更新中)
  • 3、FFmpeg基础
  • c语言:用指针解决有关字符串等问题
  • 吃透 Spring 系列—Web部分
  • JAVA后端服务端与移动端客户端高精度时间同步思路
  • nsd的资料
  • 关于Maven中pom.xml文件不报错但无法导包解决方法
  • 使用决策树分类
  • STM32H563烧录后无法擦除
  • 2023最新最全【Adobe After Effection 2023】下载安装零基础教程【附安装包】
  • 【Spring之底层核心架构概念解析】
  • 手把手带你创建一个自己的GPTs
  • Vue 组件+es6箭头函数+路由
  • Clickhouse学习笔记(5)—— ClickHouse 副本
  • ELMo模型、word2vec、独热编码(one-hot编码)的优缺点进行对比
  • FFmpeg简介1
  • Optimal Multimodal Travelway Design for an Urban Street Network
  • 2352 智能社区医院管理系统JSP【程序源码+文档+调试运行】
  • 高教社杯数模竞赛特辑论文篇-2023年B题:多波束测线布设(附获奖论文及MATLAB代码实现)(续)
  • 【fast2021论文导读】 Learning Cache Replacement with Cacheus
  • 在 React 中选择使用 JSX 或 JavaScript
  • Halcon WPF 开发学习笔记(4):Halcon 锚点坐标打印
  • 【从0到1设计一个网关】性能优化---使用Disruptor提供缓冲区
  • Redis 特殊数据类型
  • 【Windows网络编程】二.TCP套接字编程与主机上线实验
  • Qt 事件循环
  • 【趣味随笔】YOLO的“进化史”极简版(YOLO v1-->YOLOP)
  • Leetcode421. 数组中两个数的最大异或值
  • SPRINGBOOT整合CXF发布WEB SERVICE和客户端调用(用户和密码验证)
  • 代码随想录训练营Day5:哈希数组