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的内容清空。
相关推荐
海南java第二人5 小时前
Nebula Graph 实战:基于图数据库存储 CMDB 实体关系
数据库·图数据库·nebula
曹牧5 小时前
oracle:“not all variables bound”
数据库·oracle
数据库百宝箱5 小时前
Oracle RMAN Image Copy 本地恢复
数据库·oracle
zuYM4g7Dp6 小时前
NoSql数据库设计心得
数据库·nosql
睡不醒男孩0308238 小时前
第七篇:揭秘 PostgreSQL 数据库内核级管控:CLup 深度架构设计与高可用底座技术白皮书
数据库·postgresql·clup
cmes_love9 小时前
Level 2逐笔成交历史数据下载方法笔记
数据库·笔记·oracle
swordbob9 小时前
MySQL字符集陷阱:从Oracle迁移踩坑到utf8mb4强制规范
数据库·sql
牛油果子哥q9 小时前
【C++ STL string 】C++ STL string 终极精讲:底层原理、内存机制、全套API、深浅拷贝、易错坑点与工程实战规范
数据库·c++
十五年专注C++开发9 小时前
MySql中各种功能用sql语句实现总结
数据库·sql·mysql
数据库小学妹10 小时前
AI时代数据库怎么选?多模融合、数据统一存储与选型实战指南
数据库·人工智能·经验分享·ai