AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 38488
Accepted
Matt Simmons
Matt Simmons
Asked: 2009-07-10 09:42:32 +0800 CST2009-07-10 09:42:32 +0800 CST 2009-07-10 09:42:32 +0800 CST

如何判断 Oracle 数据库是否已挂载和激活?

  • 772

IANADBA,但我正在编写一个脚本,只要没有激活 oracle 备用数据库,它就会采取行动。我正在寻找的是两个查询(或查询集,如有必要)。

1 - 数据库是否已安装(例如,有人做过“alter database mount standby database”)

2 - 如何判断数据库是否已激活(如“alter database activate standby database”)?

正如我所提到的,我正在寻找查询,但如果系统中有办法告诉我,我也愿意接受。谢谢!

更新

我接受了以下建议(稍作修改,因为我正在处理 Oracle 8i,我得到了这个:

 SQL>  SELECT INSTANCE_NAME, DATABASE_STATUS, INSTANCE_ROLE from v$instance; 

 INSTANCE_NAME    DATABASE_STATUS   INSTANCE_ROLE
 ---------------- ----------------- ------------------
 RGR01            ACTIVE            PRIMARY_INSTANCE

目前,此实例正在积极恢复存档日志,但不是“实时”的。我仍在寻找一种方法来判断它是否没有作为备用数据库安装。

sql database oracle
  • 5 5 个回答
  • 98599 Views

5 个回答

  • Voted
  1. Best Answer
    Matt Simmons
    2009-07-10T11:34:08+08:002009-07-10T11:34:08+08:00

    我知道了!

    v$database 中的 CONTROLFILE_TYPE 是关键

     SQL> select CONTROLFILE_TYPE from v$database; 
    
     CONTROL
     -------
     CURRENT
    

    相对

     SQL> select CONTROLFILE_TYPE from v$database; 
    
     CONTROL
     -------
     STANDBY
    
    • 9
  2. DCookie
    2009-07-10T10:52:01+08:002009-07-10T10:52:01+08:00

    这适用于物理备用,Oracle 10g(和更高版本)

    从 v$database 中选择 open_mode;

    如果值为:

    1. 'MOUNTED',您的数据库已安装。
    2. 'READ WRITE',那么您可以假设它已被激活。
    3. 'READ ONLY' 那么它可能会以只读模式打开以进行查询,但未激活。
    4. 使用活动数据保护时“仅适用于应用”。

    在初级:

    select database_role from v$database;
    
    DATABASE_ROLE
    ----------------
    PRIMARY
    

    在奴隶上:

    OPEN_MODE
    --------------------    --------------------
    MOUNTED              or READ ONLY WITH APPLY
    

    可能还有其他值,我不确定。

    高温高压

    • 3
  3. OilyRag
    2009-07-10T10:00:06+08:002009-07-10T10:00:06+08:00

    由于我对备用数据库不太熟悉,因此这对于您所追求的可能过于简单

    但只要实例启动,您就应该能够查询 v$instance 视图并获取数据库的状态,例如

    SELECT INSTANCE_NAME, DATABASE_STATUS, INSTANCE_ROLE, ACTIVE_STATE FROM v$instance;
    
    • 1
  4. hagrawal
    2016-12-14T14:37:05+08:002016-12-14T14:37:05+08:00

    我真的不知道这个问题的答案 - “我如何判断 Oracle 数据库是否已安装和激活?”,但我必须发布答案让人们知道请不要被这篇文章的答案误导,因为大多数都是大错特错。

    • 那些说使用“v$instance”的人是绝对错误的,因为这将说明“instance”是否已安装、正在启动或是否处于活动状态。请注意,数据库和数据库实例是不同的东西,所以如果您不知道区别,那么最好阅读,并阅读有关Oracle RAC 和 Oracle Data Gurard的信息。

    • 您说的那些使用select CONTROLFILE_TYPE from v$database;也不正确,因为根据Oracle,该列讲述了控制文件信息,并告诉数据库处于备用模式还是活动模式,这与数据库是否已挂载或数据库是否处于活动状态不同。

    就像我说的,我认为了解数据库和数据库实例之间的区别以及了解什么是 Oracle RAC 和 Oracle Data Gurard 非常重要。

    假设,我有一个主数据库和另一个备用 databguard 数据库,并且两个数据库/实例都处于活动状态以供使用,但是从下面的屏幕截图中可以看出区别:

    主数据库:

    在此处输入图像描述

    备用数据保护数据库:

    在此处输入图像描述

    • 1
  5. Matt
    2009-07-10T10:02:03+08:002009-07-10T10:02:03+08:00

    你能通过 netstat/lsof 监控到数据库的连接吗?大概您会注意到客户开始使用它。

    您还可以查看这些命令的存档日志。

    • 0

相关问题

  • 远程连接 sql server 不工作,但如果防火墙禁用它呢?

  • 开源与专有关系 db mgt 系统的优缺点是什么?

  • 对于具有许多不同服务的少数服务器来说,一个好的主机名约定?

  • 如何控制 SQL Anywhere 中的临时文件增长?

  • SQL Server 2008 Express - “最佳”备份解决方案?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve