SQL语句解析类型---硬解析和软解析
一、Shared pool 作用:缓存SQL语句及SQL语句的执行计划SQL语句执行三步:解析(parse)------执行(exec)------获取数据(fetc
一、Shared pool 作用:缓存SQL语句及SQL语句的执行计划
SQL语句执行三步:解析(parse)------执行(exec)------获取数据(fetch)
shared pool的组成:
3块区域:free、librarycache、row cache(dictionary cache)
library cache:缓存SQL语句以及SQL语句的执行计划
dictionary cache:Oracle数据库自身的信息(数据库中有多少表、多少用户、表有多少列、列名是什么、列的数据类型、每个表多大)存放在dictionary中
数据字典举例:想知道数据库中有没有T1表
1、create table t1 as select * from dba_objects;
2、desc dba_tables; ---------------数据字典信息表
3、select table_name,owner from dba_tables where table_name like 'T1%’;
所有数据字典信息可在官方文档中查找booksàreferenceàdba_tables
1、查看librarycache大小
select * from v$sgastat a where a.NAME = 'library cache';
2、free空间大小
select * from v$sgastat a where a.pool = 'shared pool' anda.NAME = 'free memory';
3、row cache空间大小
select * from v$sgastat a where a.NAME = 'row cache';
二、解析:(hard parse,soft parse)
硬解析步骤:1、server process判断SQL语句语法是否有错误
2、查看SQL语句所涉及的对象是否存在(表是否存在等等)
3、执行SQL的用户对对象是否有相应权限(系统权限、对象权限)
4、生成执行计划--------一条SQL语句有多种执行方案,在N中执行方案中挑选出最优的一个最优的执行方案作为这条SQL执行计划--------最消耗资源
软解析:没有上述第四步,仅仅是常规判断
什么时候发生硬解析:
Server process 拿着SQL语句在librarycache中找,如果这条SQL语句在library cache中没有,,说明这条SQL语句和他的执行计划在library cache中没有-------硬解析
有--------软解析
无论hard parse还是soft parse,解析过程中用到很多数据库自身信息(权限信息、对象信息、对象统计信息------字典信息);即对SQL语句进行解析(软硬)的时候,都要频繁的访问数据字典信息----------所以row cache放在shared pool和library cache在一起
软硬解析的具体情况
select name,value from v$sysstat where name like 'parse%'

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

大部分用户使用Excel都是用来处理表格数据的,其实Excel还有vba程序编写,这个除了专人士应该没有多少用户用过此功能,在vba编写时常常会用到iif函数,它其实跟if函数的功能差不多,下面小编给大家介绍下iif函数的用法。Excel中SQL语句和VBA代码中都有iif函数。iif函数和excel工作表中的IF函数用法相似,执行真假值判断,根据逻辑计算的真假值,返回不同结果。IF函数用法是(条件,是,否)。VBA中的IF语句和IIF函数,前者IF语句是控制语句可以根据条件执行不同的语句,后者

Oracle数据库的日志信息可以通过以下方法查询:使用SQL语句从v$log视图查询;使用LogMiner工具分析日志文件;使用ALTER SYSTEM命令查看当前日志文件的状态;使用TRACE命令查看特定事件的信息;使用操作系统工具查看日志文件的末尾部分。

要查询 MySQL 数据库存储结构,可以使用以下 SQL 语句:SHOW CREATE TABLE table_name;该语句将返回表的列定义和表选项的信息,包括列的名称、数据类型、约束和表的一般属性,例如存储引擎和字符集。

在 Navicat 中导出查询结果:执行查询。右键单击查询结果并选择“导出数据”。根据需要选择导出格式:CSV:字段分隔符为逗号。Excel:包括表头,使用 Excel 格式。SQL 脚本:包含用于重新创建查询结果的 SQL 语句。选择导出选项(如编码、换行符)。选择导出位置和文件名。单击“导出”以开始导出。

要解决MySQL数据库初始化失败问题,请遵循以下步骤:检查权限并确保使用有适当权限的用户。如果数据库已存在,请删除它或选择不同的名称。如果表格已存在,请删除它或选择不同的名称。检查SQL语句是否存在语法错误。确认MySQL服务器正在运行且可连接。验证您使用的是正确的端口号。查看MySQL日志文件或错误代码查找器以获取其他错误的详细信息。

可以通过以下方法执行 MySQL SQL 语句:使用 MySQL CLI(命令行界面):登录数据库并输入 SQL 语句。使用 MySQL Workbench:启动应用程序、连接数据库并执行语句。使用编程语言:导入 MySQL 连接库、创建数据库连接并执行语句。使用其他工具(例如 DB Browser for SQLite):下载并安装应用程序、打开数据库文件并执行语句。

MySQL事务处理:自动提交与手动提交的区别在MySQL数据库中,事务是一组SQL语句的集合,要么全部执行成功,要么全部执行失败,保证了数据的一致性和完整性。在MySQL中,事务可以分为自动提交和手动提交,其区别在于事务提交的时机以及对事务的控制范围。下面将详细介绍自动提交和手动提交的区别,并给出具体的代码示例来说明。一、自动提交在MySQL中,如果没有显示

MySQL与PL/SQL是两种不同的数据库管理系统,分别代表了关系型数据库和过程化语言的特点。本文将比较MySQL和PL/SQL的异同点,并附带具体的代码示例进行说明。MySQL是一种流行的关系型数据库管理系统,采用结构化查询语言(SQL)来管理和操作数据库。而PL/SQL是Oracle数据库特有的过程化语言,用于编写存储过程、触发器和函数等数据库对象。相同
