首页 > 解决方案 > Oracle系统信息查询——数据库实例级

问题描述

我正在编写一个性能/系统监控工具来增加我团队产品的负载测试,我正在尝试将数据库系统信息与结果包一起存储,但不知道如何编写查询以在 Oracle 中捕获它(我是一名开发人员不是 DBA)。

对于 SQL Server,这一切都按照我想要的方式工作,但我需要对 Oracle 做同样的事情。下面是我在网上找到的一个查询,它是 SQL Server:

SELECT CONVERT(varchar(128),SERVERPROPERTY('ComputerNamePhysicalNetBIOS')) AS 'computerNamePhysicalNetBIOS', 
CONVERT(varchar(128),SERVERPROPERTY('MachineName')) AS 'machineName', 
CONVERT(varchar(128),SERVERPROPERTY('Edition')) AS 'edition', 
CONVERT(varchar(128),SERVERPROPERTY('ProductLevel')) AS 'productLevel', 
CONVERT(varchar(128),SERVERPROPERTY('ProductVersion')) AS 'productVersion', 
CONVERT(varchar(128),SERVERPROPERTY('BuildClrVersion')) AS 'buildClrVersion', 
CONVERT(INT,SERVERPROPERTY('ProcessID')) AS 'processID', 
CONVERT(INT,SERVERPROPERTY('EngineEdition')) AS 'engineEdition', 
CONVERT(INT,SERVERPROPERTY('HadrManagerStatus')) AS 'hadrManagerStatus', 
CONVERT(INT,SERVERPROPERTY('IsHadrEnabled')) AS 'hadrEnabled', 
CONVERT(INT,SERVERPROPERTY('IsAdvancedAnalyticsInstalled')) AS 'advancedAnalyticsInstalled', 
CONVERT(INT,SERVERPROPERTY('IsClustered')) AS 'clustered', 
CONVERT(INT,SERVERPROPERTY('IsPolybaseInstalled')) AS 'polybaseInstalled', 
CONVERT(INT,SERVERPROPERTY('IsXTPSupported')) AS 'xtpSupported', 
CONVERT(INT,SERVERPROPERTY('LCID')) AS 'lcid', 
CONVERT(varchar(128),SERVERPROPERTY('ResourceVersion')) AS 'resourceVersion', 
CONVERT(varchar(128),SERVERPROPERTY('ServerName')) AS 'serverName', 
CONVERT(varchar(128),APP_NAME() )AS 'appName', 
CONVERT(INT,DB_ID()) AS 'dbId', 
CONVERT(varchar(128),DB_NAME()) AS 'dbName'

我真的不希望上述查询与 Oracle 版本之间存在一对一的列匹配,但总的来说,我如何从 Oracle 获得非常相似的信息?

标签: sqloraclemetadata

解决方案


我真的不希望上述查询和 Oracle 版本之间存在一对一的列匹配,但总的来说,我如何从 Oracle 获得非常相似的信息?

大多数这些东西,如果它存在于 Oracle 数据库中的话,将可以通过 Oracle 数据库中的 V$ 视图访问。为了让您开始,这里有一些与回答您的问题最相关的内容:

select * from v$instance;

select * from v$version;

select * from v$sql_feature;

select * from v$license;

select * from v$option;

如果您想获得完整的 V$ 视图列表以便更好地环顾四周,

select * from dict where table_name like 'V$%';

推荐阅读