Administración de Oracle
Recopilación de consultas SQL útiles para el administrador de Oracle:
Estado de la base de datos
select * from v$instance
Parámetros generales de Oracle
select * from v$system_parameter
Versión de Oracle
select value from v$system_parameter where name = 'compatible'
Ubicación y nombre del fichero spfile
select value from v$system_parameter where name = 'spfile'
Ubicación y número de ficheros de control
select value from v$system_parameter where name = 'control_files'
Nombre de la base de datos
select value from v$system_parameter where name = 'db_name'
Conexiones actuales a la Base de Datos:
select osuser, username, machine, program from v$session order by osuser
Diccionario de datos (incluye todas las vistas y tablas de la Base de Datos)
Tablas propiedad del usuario actual
Parámetros de Oracle, valor actual y su descripción:
Últimas consultas SQL ejecutadas en Oracle y usuario que las ejecutó:
select * from dictionary
select * from user_tables
Todos los objetos propiedad del usuario conectado a Oracle
select * from user_catalog
Consulta SQL para el DBA de Oracle que muestra los tablespaces, el espacio utilizado,
el espacio libre y los ficheros de datos de los mismos:
Select t.tablespace_name "Tablespace", t.status "Estado", ROUND(MAX(d.bytes)/1024/1024,2) "MB Tamaño", ROUND((MAX(d.bytes)/1024/1024) - (SUM(decode(f.bytes, NULL,0, f.bytes))/1024/1024),2) "MB Usados", ROUND(SUM(decode(f.bytes, NULL,0, f.bytes))/1024/1024,2) "MB
Libres", t.pct_increase "% incremento", SUBSTR(d.file_name,1,80) "Fichero de datos"
FROM DBA_FREE_SPACE f, DBA_DATA_FILES d, DBA_TABLESPACES t WHERE t.tablespace_name = d.tablespace_name AND
f.tablespace_name(+) = d.tablespace_name AND f.file_id(+) = d.file_id GROUP BY t.tablespace_name, d.file_name, t.pct_increase, t.status ORDER BY 1,3 DESC
Productos Oracle instalados y la versión:
select * from product_component_version
Roles y privilegios por roles:
select * from role_sys_privs
Reglas de integridad y columna a la que afectan:
select constraint_name, column_name from sys.all_cons_columns
SELECT v.name, v.value value, decode(ISSYS_MODIFIABLE, 'DEFERRED', 'TRUE', 'FALSE') ISSYS_MODIFIABLE, decode(v.isDefault, 'TRUE',
'YES', 'FALSE', 'NO') "DEFAULT", DECODE(ISSES_MODIFIABLE, 'IMMEDIATE', 'YES','FALSE', 'NO', 'DEFERRED', 'NO', 'YES') SES_MODIFIABLE, DECODE(ISSYS_MODIFIABLE, 'IMMEDIATE', 'YES', 'FALSE', 'NO', 'DEFERRED', 'YES','YES') SYS_MODIFIABLE , v.description
FROM V$PARAMETER v WHERE name not like 'nls%' ORDER BY 1
Usuarios de Oracle y todos sus datos (fecha de creación, estado, id, nombre, tablespace temporal,...):
Select * FROM dba_users
select distinct vs.sql_text, vs.sharable_mem, vs.persistent_mem, vs.runtime_mem, vs.sorts, vs.executions, vs.parse_calls, vs.module, vs.buffer_gets, vs.disk_reads, vs.version_count, vs.users_opening, vs.loads, to_char(to_date(vs.first_load_time, 'YYYY-MM-DD/HH24:MI:SS'),'MM/DD HH24:MI:SS') first_load_time, rawtohex(vs.address) address, vs.hash_value hash_value , rows_processed , vs.command_type, vs.parsing_user_id , OPTIMIZER_MODE , au.USERNAME parseuser
from v$sqlarea vs , all_users au where (parsing_user_id != 0) AND (au.user_id(+)=vs.parsing_user_id) and (executions >= 1) order by buffer_gets/executions desc
Todos los ficheros de datos y su ubicación:
select * from V$DATAFILE
Ficheros temporales:
select * from V$TEMPFILE
Tablespaces:
select * from V$TABLESPACE
Comentarios