Oracle 初始化参数&性能视图

《Oracle初始化参数性能视图》1.数据库版本LEO1@LEO1select*fromv$version;BANNER————————————————————————–

oracle 初始化参数&性能视图》

1.数据库版本

LEO1@LEO1>select * from v$version;

BANNER

——————————————————————————–

Oracle Database11g Enterprise Edition Release 11.2.0.1.0 – 64bit Production

PL/SQL Release11.2.0.1.0 – Production

CORE    11.2.0.1.0      Production

TNS for Linux:Version 11.2.0.1.0 – Production

NLSRTL Version11.2.0.1.0 – Production

2.设置memory_target参数,并通过v$memory_target_advice分析数据库的最佳内存大小

Memory_target:1.是oracle11g中的一个内存调整参数,11g对自动化管理内存方面又继续加强了,原来10g中可以对SGA进行自动管理与分配,11g即可以自动管理SGA,又可以自动管理PGA,对这两部分进行综合管理,自动调整所有内存区的大小。11g中默认为0

现在把这几个参数语法列举一下,这是静态参数需要重启数据库生效

alter systemset memory_max_target= 1000m scope=spfile;
alter system set  memory_target= 1000m scope=spfile;
alter system set sga_max_size=600m scope=spfile;
alter system set pga_aggregate_target=400m scope=spfile;

2.memory_max_target 是设定 Oracle 能占物理内存多大空间,一个是 Oracle SGA 区最大能占多大内存空间+PGA区多大空间,memory_max_target是memory_target上限值,如果只设置了memory_max_target没有设置memory_target,则Oracle认为memory_target=0不使用内存自动管理。

3.如果只设置memory_target,没有设置memory_max_target,则Oracle自动将memory_max_target设置为memory_target。

4.如果同时设置这两个值,则memory_target的上限值为memory_max_target。

这是我的数据库上的参数值

LEO1@LEO1> showparameter memory_max_target

NAME                                 TYPE        VALUE

———————————————– ——————————

memory_max_target                    big integer 652M

LEO1@LEO1> showparameter memory_target

NAME                                 TYPE        VALUE

———————————————– ——————————

memory_target                        big integer 652M

5. 10g 的sga_max_size 是动态分配 Shared Pool Size,database buffer cache,largepool,java pool,redo log buffer 大小的,根据 Oracle 运行状态来重新分配 SGA 各内存区大小。 PGA 在 10g 中需要单独设定(即手工管理)。

实验

下面我们通过以下的几个命令来让大家清楚memory_target 的设置与PGA和SGA的关系

(1)memory_target设置为非0值

Memory_Target=SGA_TARGET+PGA_AGGREGATE_TARGET  ,大小等于memory_max_size 一致。

AI改图神器 AI改图神器

AI万能图片编辑器,一键抠图,去水印,智能图片美化,照片转漫画,照片变活转视频,图片无损放大,一键背景虚化,位图智能转矢量图

AI改图神器 37 查看详情 AI改图神器

sga_target和pga_aggregate_target都设置了大小,则这两个参数将做为最小起始值

sga_target  设置大小, pga_aggregate_target  没有设置大小  

          那么 pga_aggregate_target 初始化值 =memory_target-sga_target

sga_target  没有设置大小, pga_aggregate_target  设置大小  

          那么 sga_target 初始化值 =memory_target-pga_aggregate_target

sga_target  和pga_aggregate_target都没有设置大小 Oracle 11g 将根据数据库运行状态自动分配大小。但在数据库启动时会有一个固定比例来分配:

        sga_target =memory_target *60%     pga_aggregate_target=memory_target *40%

(2)memory_target没有设置或等于0(11g中默认为0)

11g中默认为0则初始状态下取消了 memory_target 的作用,完全和10g在内存管理上一致,完全向下兼容。

   (也有三种情况来对 SGA 和 PGA 的大小进行分配)

SGA_TARGET 设置值,则自动调节 SGA 中的 shared pool,buffer cache,redo logbuffer,java pool,larger pool内存区,PGA 则依赖 pga_aggregate_target 的大小单独设置。 sga和 pga不能自动增长和自动缩小。

SGA_target 和PGA_AGGREGATE_TARGET 都没有设置,SGA 中的各内存区大小都要明确设定,不能自动调整各内存区大小。PGA 不能自动增长和收缩。

memory_max_target设置而memory_target =0  这种情况和10g 一样不使用内存自动管理

LEO1@LEO1> showparameter target

NAME                           TYPE        VALUE

———————————————– ——————————

archive_lag_target                  integer    0

db_flashback_retention_target        integer     1440

fast_start_io_target                 integer     0

fast_start_mttr_target               integer     0

memory_max_target                big integer  652M

memory_target                    big integer  652M

parallel_servers_target              integer     8

pga_aggregate_target               big integer  0

sga_target                        big integer  0

现在我们看到sga_target和pga_aggregate_target的值都是0,由oracle自动调整大小,memory_target和memory_max_target的大小是652M

LEO1@LEO1>select * from v$memory_target_advice;    分析数据库最佳内存大小

MEMORY_SIZE MEMORY_SIZE_FACTORESTD_DB_TIME ESTD_DB_TIME_FACTOR   VERSION

—————————– ———— ——————- ———-

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/524840.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月9日 07:20:40
下一篇 2025年11月9日 07:26:22

相关推荐

  • SQLAlchemy声明式模型中指定数据库表Schema的方法

    本文详细介绍了如何在sqlalchemy的声明式模型中为数据库表指定schema。通过在模型类中利用`__table_args__`属性,开发者可以轻松地将表关联到特定的数据库schema,从而更好地组织和管理数据库结构,尤其适用于支持schema的数据库如postgresql,并提供了完整的代码示…

    2025年12月14日
    000
  • 使用SQLAlchemy声明式ORM指定数据库表Schema的教程

    本文详细介绍了如何在sqlalchemy声明式orm中为数据库表指定特定的schema,而非使用数据库的默认schema。通过利用模型类中的`__table_args__`属性,并设置`schema`参数,开发者可以灵活地控制表在不同命名空间中的创建位置。文章将提供具体的代码示例和使用指南,并探讨此…

    2025年12月14日
    000
  • Python代码如何连接MySQL数据库 Python代码使用PyMySQL驱动的连接方法

    答案:PyMySQL是纯Python实现的MySQL驱动,安装简单、跨平台兼容性好,支持参数化查询和DictCursor返回字典结果,避免SQL注入并提升代码可读性;实际项目中应通过环境变量或配置文件管理数据库凭证以确保安全,并使用DBUtils等工具构建连接池提升高并发场景下的性能;处理大数据量时…

    2025年12月14日
    000
  • 使用pip管理和解决mysql-connector-python安装问题

    本教程详细介绍了如何使用pip安装python的mysql连接器mysql-connector-python。针对pip提示“requirement already satisfied”但仍需重新安装的情况,文章提供了手动清理现有包文件的方法,确保顺利完成安装过程,并避免常见的环境冲突问题,帮助开发…

    2025年12月14日
    000
  • 解决Oracle中pd.read_sql的IN子句参数绑定问题

    本文探讨了在使用pandas的`pd.read_sql`函数查询oracle数据库时,针对`in`子句无法直接绑定python元组或列表参数的`databaseerror`问题。核心内容是揭示oracle驱动的参数绑定机制,并提供一种将元组/列表动态展开为多个命名参数的有效解决方案,确保sql查询的…

    2025年12月14日
    000
  • cx_Oracle查询调试:如何查看实际执行的参数化SQL语句

    本文旨在指导如何在cx_Oracle中调试参数化SQL查询。我们将深入理解cx_Oracle如何安全地处理绑定变量,避免SQL注入,并介绍通过设置PYO_DEBUG_PACKETS环境变量来查看发送至数据库的实际数据包,从而验证查询语句和参数。此外,还将探讨查询无结果的常见原因,如遗漏数据获取操作或…

    2025年12月14日
    000
  • cx_Oracle参数化查询的调试与验证

    本文深入探讨了在cx_Oracle中调试SQL查询时如何理解参数绑定机制、验证实际发送的数据库请求,并解决常见的查询无结果问题。文章阐明了cx_Oracle通过绑定变量而非字符串插值来防止SQL注入,并提供了利用PYO_DEBUG_PACKETS环境变量检查网络数据包的方法,同时强调了执行curso…

    2025年12月14日
    000
  • 调试cx_Oracle查询:深入理解参数绑定与网络包分析

    本文将深入探讨在使用cx_Oracle执行SQL查询时,如何有效调试参数绑定过程并验证实际发送到数据库的查询内容。我们将澄清关于参数替换的常见误解,介绍如何利用PYO_DEBUG_PACKETS环境变量来监控网络流量,从而查看原始SQL语句和绑定参数,并强调获取查询结果的关键步骤及其他常见调试要点,…

    2025年12月14日
    000
  • 调试cx_Oracle查询:理解绑定变量与查看实际执行的SQL

    在使用cx_Oracle进行数据库操作时,理解绑定变量的工作机制至关重要。本文旨在阐明cx_Oracle如何通过绑定变量安全地执行参数化查询,而非字符串拼接,并提供一种有效的调试方法——利用PYO_DEBUG_PACKETS环境变量来查看实际发送到数据库服务器的低级别通信,从而验证查询的正确性。此外…

    2025年12月14日
    000
  • cx_Oracle:查看绑定参数后的SQL查询与调试技巧

    本文详细介绍了在cx_Oracle中调试SQL查询和验证参数绑定的方法。它阐明了cx_Oracle如何通过参数绑定安全地处理查询,而非字符串插值,从而有效防止SQL注入。同时,教程还提供了使用PYO_DEBUG_PACKETS%ignore_a_1%来查看底层通信包以确认实际发送到数据库的查询,并强…

    2025年12月14日
    000
  • Python怎么连接MySQL数据库_PyMySQL与mysql-connector-python使用教程

    Python连接MySQL常用PyMySQL和mysql-connector-python,前者纯Python实现易部署,后者官方出品性能强兼容好;核心步骤包括连接、游标、执行、提交、关闭;选择依据项目需求与团队偏好。 Python连接MySQL数据库,通常我们会借助第三方库来实现。目前最主流且推荐…

    2025年12月14日
    000
  • Python怎样操作数据库_Python数据库CRUD步骤解析

    Python操作数据库需通过驱动建立连接并执行SQL,遵循连接、创建游标、执行SQL、提交事务、关闭连接的流程,使用参数化查询防SQL注入,结合try-except-finally管理事务确保数据一致性。 Python操作数据库的核心在于通过特定的数据库驱动(如 sqlite3 、 psycopg2…

    2025年12月14日
    000
  • 在SQLAlchemy中正确使用DB-API风格的绑定参数执行SQL语句

    本文探讨了在SQLAlchemy 2.0中,使用DB-API风格的绑定参数执行原始SQL语句时遇到的常见ArgumentError问题,特别是当参数包含日期时间对象时。文章详细解释了该错误的原因,并提供了解决方案:利用sql_conn.exec_driver_sql()方法,该方法能直接将SQL命令…

    2025年12月14日
    000
  • 使用 PySpark 将 JSON 属性数据透视为表格列

    本教程详细介绍了如何使用 PySpark 将 Oracle REST API 返回的 JSON 数组数据(其中属性名和属性值以键值对形式存在)转换为结构化的表格格式。通过 PySpark 读取 JSON 数据并结合 Spark SQL 的 MAX(CASE WHEN …) 语句,实现将动…

    2025年12月14日
    000
  • 使用 PySpark 从 JSON 对象中选择并透视数据

    本文档介绍了如何使用 PySpark 从包含属性和值的 JSON 对象中提取特定列,并将其透视为所需格式。通过创建 DataFrame 和使用 Spark SQL,我们可以灵活地选择和转换数据,最终得到以指定属性名作为列名的结果。本文提供详细步骤和示例代码,帮助你轻松完成数据提取和转换任务。 使用 …

    2025年12月14日
    000
  • Python怎样操作MariaDB数据库?mariadb连接器

    python操作mariadb应优先选择pymysql或mysql-connector-python,pymysql因纯python实现、安装简便、社区活跃而更适合大多数场景;2. 防止sql注入必须使用参数化查询,通过占位符(如%s)与参数元组分离sql结构与数据,避免恶意输入篡改语句;3. 事务…

    2025年12月14日
    000
  • Python连接MySQL 5.1:克服旧版认证与字符集兼容性挑战

    本教程详细阐述了如何使用Python 3和mysql.connector库成功连接到老旧的MySQL 5.1数据库。文章重点介绍了解决旧版认证协议和字符集兼容性问题的关键配置,特别是use_pure=True和charset=’utf8’的重要性,并提供了可运行的代码示例。同…

    2025年12月14日
    000
  • 使用 python-oracledb 连接 Oracle 数据库:解决安装难题

    本文旨在帮助读者解决在使用 Python 连接 Oracle 数据库时遇到的安装问题。由于 cx_Oracle 已被 python-oracledb 取代,针对新版本 Python 的预编译二进制文件仅适用于 python-oracledb。本文将指导您如何正确安装和配置 python-oracle…

    2025年12月14日
    000
  • Python中如何加密数据?

    使用python加密数据的方法包括:1. 使用hashlib库生成哈希值,如sha-256;2. 使用cryptography库进行对称加密,如fernet;3. 使用cryptography库进行非对称加密,如rsa。通过这些方法,开发者可以有效保护数据安全。 引言 当我们谈到数据安全时,加密成为…

    2025年12月13日
    000
  • Python在数据库操作方面有哪些应用?如何连接数据库?

    python在数据库操作方面的应用包括数据分析和处理、web应用的后端开发、数据科学与机器学习、自动化任务。连接数据库的方法包括:1. 连接mysql数据库,使用mysql-connector-python库。2. 连接postgresql数据库,使用psycopg2库。3. 连接sqlite数据库…

    2025年12月13日
    000

发表回复

登录后才能评论
关注微信