oracle-sql语句解析类型

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

1. shared pool的组成。

share pool是一块内存池。

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

sql 复制代码
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种执行方案中挑选出最优的执行方案作为执行计划。

软硬解析具体情况。

sql 复制代码
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在哪个链条上。

sql 复制代码
select count(*) from x$ksmsp;  -- shared pool的总的chunk数

 alter system flush shared_pool;  -- 将shared pool的library cache和row cache的内容清空。
相关推荐
l1t5 分钟前
DeepSeek对AliSQL 集成 DuckDB 的总结
数据库·sql·mysql·duckdb
想起你的日子17 分钟前
ASP.NET Core EFCore之DB First
数据库·.netcore
SeaTunnel21 分钟前
Apache SeaTunnel MySQL CDC 支持按时间启动吗?
大数据·数据库·mysql·开源·apache·seatunnel
韩立学长32 分钟前
Springboot喵趣网上宠物店的设计和实现5pidz60b(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
深耕AI1 小时前
【wordpress系列教程】07 网站迁移与备份
运维·服务器·前端·数据库
刘大猫.1 小时前
XNMS项目-mysql数据库同步
数据库·统计·同步·数据同步·数据统计·数据库同步·业务统计
踢足球09292 小时前
寒假打卡:2026-01-22
数据库·sql
数巨小码人2 小时前
核心架构深度解析-揭开国产数据库内核的神秘面纱
数据库·架构
薛晓刚2 小时前
MySQL 精度扩展时候的DDL阻塞对比Oracle
数据库
卓怡学长2 小时前
m119在线购书商城系统
java·数据库·spring boot·spring·汽车