Mi lista de blogs

jueves, 20 de agosto de 2015

CREAR DBLINK EN DATABASE ORACLE

DB LINK

1. Primero debemos abrir el tnsname.
2. Entramos al tnsname y creamos la conexión.

SQL> desc DBA_DB_LINKS
 Name                                      Null?                              Type
 ----------------------------------------- -------- ----------------------------
 OWNER                                     NOT NULL      VARCHAR2(30)
 DB_LINK                                   NOT NULL       VARCHAR2(128)
 USERNAME                                                                 VARCHAR2(30)
 HOST                                                                          VARCHAR2(2000)
 CREATED                                   NOT NULL     DATE

O lo editamos



Creamos el DBLINK

Create public/private database_link linkname connect to username identified by Password using ‘Service Name’; i

Ejemplo:

Create DBLINK

CREATE PUBLIC DATABASE LINK "TESTING" CONNECT TO USER IDENTIFIED BY PASSWORD USING 'TESTING.WORLD’;

La configuración de nuestro TNSNAME es :


TESTING.WORLD
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 10.170.68.83)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SID = SXXX
      (SERVER = TEST)
    )
  )


sqlplus  / as sysdba

CREATE public DATABASE LINK NAMELINK CONNECT TO USERLINK IDENTIFIED BY password USING
'(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=hostname.domainname.com)(PORT=1521)))
(CONNECT_DATA=(SID = SXXX')));


Chequeamos el DB link :

select * from dual@NAMELINK;

Select * from dba_db_links;


DROP DBLINK:

DROP PUBLIC DATABASE LINK "NAMELINK.WORLD";

Algunos comandos para utilizar en unix

1.- Lee y abre un archivo.

cat nombre-archivo

2.- Crear un archivo nuevo

cat > archivo-destino

3.- Abrir un archivo, numerando todas las líneas

cat -b nombre-archivo

4.- Lee y abre el archivo mostrándome cada fin de línea con un signo $.

cat -e nombre-archivo

5.- Lee y Abre un archivo, numerando todas las líneas.

cat -n nombre-archivo

6.- Lee y abre el archivo eliminando todas las líneas de espacio redundantes.

cat -r nombre-archivo

7.- Lee y abre el archivo omitiendo sus mensajes de error.

cat -s nombre-archivo

8.- Lee y abre el archivo mostrándome cada tabulación con el signo ^I.

cat -t nombre-archivo

9.- Lee y abre el archivo sin ponerlo en un buffer.

cat -u nombre-archivo

10.- Lee y abre el archivo, entregando la mayor información posible.
cat -v nombre-archivo

11.- Concatena uno o dos archivos en el primer archivo.

cat archivo1 archivo2 > archivo1

12.- Concatena uno o dos archivos a un tercer archivo.

cat archivo1 archivo2 > archivo3

13. Ver en que directorio estoy

pwd

14. ver los files del directorio donde estos

ls

15.  ir para atras

cd ..

16. Ir a un directorio

cd /directorio

17. Espacio free y usado

df -g






miércoles, 19 de agosto de 2015

Plan de contigencia


Plan de contingencia


1 - ¿Que es un plan de contingencia?
2 - ¿ Como crear una contingencia?
3 - ¿ Plan y mantenimiento de procesos de copia?
4 - ¿Como mantener actualizada mi contingencia?



La contingencia, se entiende en el ámbito de sistemas, como un método de poder restablecer la conexión o los sistemas que tengan un incidente en un ambiente productivo. Es decir, sera el plan de contingencia que deberá considerarse para poder obtener una solución ante un problema critico.
Nosotros, hablaremos de un plan de contingencia basado en una base de datos.


Para crear una contingencia, hay que considerar primero un servidor donde podamos localizar la base de datos, donde esta base sera la que restauraremos en caso de tener una perdida parcial o total de la base productiva.

Es importante tener activo en nuestra base, nuestro metodo de backup, tanto el full como el archive log.

Una consideración muy importante, es tener presente la politica de backup que hemos aplicado para nuestra base. Es decir: que si nuestro backup full se ejecuta todas las noches y luego tenemos en el día nuestros archive logs, debemos considerar estos como elementos fundamentales.

Una vez que tengamos estos puntos en claro comenzaremos a formular un proceso de contingencia.
Yo en este blog haré un ejemplo concreto y breve, para no hacerlo muy extenso.

Entonces, como segundo paso; 2 - ¿ Como crear una contingencia?

Primero, realizaremos una copia igual o clonado del servidor de producción, dejando así los mismos archivos.
A su vez, si hemos realizado un clon del servidor ya tenemos nuestra base, solo nos va a faltar configurarla. En caso contrario, debemos hacer una instalación de la base y un restore de la productiva. Vamos a considerar que se realizo el clon del servidor productivo, entonces haremos primero una bajada de la base, así no esta activa, para no producir problemas.

Luego; 3 - ¿ Plan y mantenimiento de procesos de copia?

Utilizaremos una herramienta o una tarea programada, para que luego del backup full se copie los objetos a nuestro server de contingencia. Esto lo realizaremos o dejaremos programado para que se haga luego del backup full. Luego, dejaremos configurada, si es que contamos con una herramienta licenciada, una tarea para copiar los archive logs cada 30 minutos. Estos backups serán copiados al server de contingencia.

Esto debemos tenerlo en cuenta para 4 - ¿Como mantener actualizada mi contingencia?

Es importante, realizar pruebas periodicas para validar los tiempos que demora el restore.
En mi experiencia, implemente un menu en unix para que cualquier integrante del equipo pueda realizar la tarea de dicho restore. Esta demas aclarar que yo al realizar esta contingencia, genere los documentos necesarios para cuando la necesiten aplicar. Los pasos dentro del menu de unix que utilice son:
1-Recuperación de la base -- Esto aplica el restore del backup full
2-Aplicar archive logs -- Como dice el menu actualiza la base al ultimo archive
3-Levantar la base
4-Generar backup

Este es un concepto general del armado de contingencia, a tener en cuenta que es de mucha importancia dejar sentado cada paso de los cambios, Las contingencias deben ser armadas con una metodología y criterio para que aegure la continuidad del negocio.

martes, 18 de agosto de 2015

¿Que es un Store Procedure?

Un procedimiento almacenado (stored procedure ) es un programa almacenado físicamente en una base de datos.
Los procedimiento almacenado al ser ejecutados, tienen un tiempo de respuesta a una petición de usuario y es ejecutado directamente en el motor de bases de datos, el cual usualmente corre en un servidor separado. Posee acceso directo a los datos que necesita manipular y sólo necesita enviar sus resultados de regreso al usuario, deshaciéndose de la sobrecarga resultante de comunicar grandes cantidades de datos salientes y entrantes.

¿QUE ES UN QUERY?

¿QUE ES UN QUERY?
Un query es una consulta.
Un query en base de datos es una búsqueda o pedido de datos almacenados en una base de datos.
La misma, se ejecuta por medio de sentencias o comandos, donde sea interpretado de forma correcta sobre el lenguaje que estamos aplicando dicha consulta.

Ejemplo: Select * from Nombre_de_tabla
Este Select, me va a trae el resultado que contiene la tabla "Nombre_de_tabla".

Oracle Flashback Query


Flashback by SCN

SELECT <column_name_list>
FROM <table_name>
AS OF <SCN>
[WHERE <filter_conditions>]
[GROUP BY <unaggregated columns>]
[HAVING <group_filter>]
[ORDER BY <column_positions_or_name>]
conn uwclass/uwclass

CREATE TABLE t AS
SELECT owner, table_name, tablespace_name
FROM all_tables
WHERE 1=2;

desc t

SELECT current_scn, SYSTIMESTAMP
FROM v$database;
-- 5604676 18-AUG-15 10.54.39.218000 AM -10:00

INSERT INTO t VALUES ('A', 'AAAAA', 'AAAAAAAAAA');

COMMIT;

SELECT current_scn, SYSTIMESTAMP
FROM v$database;
-- 5604687 18-AUG-15 10.55.01.984000 AM -10:00

INSERT INTO t VALUES ('B', 'BBBBB', 'BBBBBBBBBB');

COMMIT;

SELECT current_scn, SYSTIMESTAMP
FROM v$database;
-- 5604694 18-AUG-15 10.55.14.421000 AM -10:00

INSERT INTO t VALUES ('C', 'CCCCC', 'CCCCCCCCCC');

COMMIT;

SELECT current_scn, SYSTIMESTAMP
FROM v$database;
-- 5604700 18-AUG-15 10.55.26.218000 AM -10:00

SELECT * FROM t;

sqlplus / as sysdba

set linesize 121
col owner format a10

SELECT owner, table_name, tablespace_name
FROM uwclass.t
AS OF SCN 5604684;

SELECT owner, table_name, tablespace_name
FROM uwclass.t
AS OF SCN 5604685;

SELECT owner, table_name, tablespace_name
FROM uwclass.t
AS OF SCN 5604691;

SELECT owner, table_name, tablespace_name
FROM uwclass.t
AS OF SCN 5604692;

SELECT owner, table_name, tablespace_name
FROM uwclass.t
AS OF SCN 5604697;

SELECT owner, table_name, tablespace_name
FROM uwclass.t
AS OF SCN 5604698;

SELECT owner, table_name, tablespace_name
FROM uwclass.t
AS OF TIMESTAMP TO_TIMESTAMP('18-AUG-15 10.55.20.000000');

Flashback by Timestamp

ELECT <column_name_list>
FROM <table_name>
AS OF <TIMESTAMP>
[WHERE <filter_conditions>]
[GROUP BY <unaggregated columns>]
[HAVING <group_filter>]
[ORDER BY <column_positions_or_name>]
conn uwclass/uwclass

CREATE TABLE t AS
SELECT owner, table_name, tablespace_name
FROM all_tables
WHERE 1=2;

desc t

SELECT current_scn, SYSTIMESTAMP
FROM v$database;
-- 5604676 18-AUG-15 10.54.39.218000 AM -10:00

INSERT INTO t VALUES ('A', 'AAAAA', 'AAAAAAAAAA');

COMMIT;

SELECT current_scn, SYSTIMESTAMP
FROM v$database;
-- 5604687 18-AUG-15 10.55.01.984000 AM -10:00

INSERT INTO t VALUES ('B', 'BBBBB', 'BBBBBBBBBB');

COMMIT;

SELECT current_scn, SYSTIMESTAMP
FROM v$database;
-- 5604694 18-AUG-15 10.55.14.421000 AM -10:00

INSERT INTO t VALUES ('C', 'CCCCC', 'CCCCCCCCCC');

COMMIT;

SELECT current_scn, SYSTIMESTAMP
FROM v$database;
-- 5604700 18-AUG-15 10.55.26.218000 AM -10:00

SELECT * FROM t;

sqlplus / as sysdba

set linesize 121
col owner format a10

SELECT owner, table_name, tablespace_name
FROM uwclass.t
AS OF TIMESTAMP TO_TIMESTAMP('18-AUG-15 10.55.00.000000');
Flashback by SCN
SELECT owner, table_name, tablespace_name
FROM uwclass.t
AS OF TIMESTAMP TO_TIMESTAMP('18-AUG-15 10.55.10.000000');

SELECT owner, table_name, tablespace_name
FROM uwclass.t
AS OF TIMESTAMP TO_TIMESTAMP('18-AUG-15 10.55.20.000000');

SELECT owner, table_name, tablespace_name
FROM uwclass.t
AS OF TIMESTAMP TO_TIMESTAMP('18-AUG-15 10.55.40.000000');


AS OF Demo

CREATE TABLE t AS
SELECT *
FROM dba_objects
WHERE 1=2;

SELECT COUNT(*)
FROM t;

SELECT current_scn
FROM v$database;

INSERT INTO t
SELECT *
FROM dba_objects
WHERE rownum < 101;

COMMIT;

SELECT current_scn
FROM v$database;

INSERT INTO t
SELECT *
FROM dba_objects
WHERE rownum < 1001;

COMMIT;

SELECT current_scn
FROM v$database;

INSERT INTO t
SELECT *
FROM dba_objects
WHERE rownum < 10001;

COMMIT;

SELECT current_scn
FROM v$database;

SELECT COUNT(*)
FROM t
AS OF SCN 15263767;

SELECT COUNT(*)
FROM t
AS OF SCN 15263775;

SELECT COUNT(*)
FROM t
AS OF SCN 15263786;

SELECT COUNT(*)
FROM t

AS OF SCN 15263804;


jueves, 13 de agosto de 2015

Activar el modo de archive log de una base de datos Oracle

Activar el modo de archive log de una base de datos Oracle

Abriremos la aplicación SQL Plus de Oracle 

sqlplus /nolog

Nos conectamos con un usuario con suficientes privilegios y ejecutamos el comando:

connect usuario/contraseña@NOMBRE_BASE_DATOS as sysdba

Si la base de datos está en modo OPEN Nos dará un error::

alter database archivelog;

Para poder cambiar la base de datos Oracle a modo archive log hay que iniciarla en modo "mount" 
Ejecutamos

shutdown immediate;
Resultado :

Database closed.
Database dismounted.
ORACLE instance shut down.

La iniciamos en modo "mount" con el comando:

startup mount;


Resultado comando:

ORACLE instance started.
..
..
..
Database mounted.

Para cambiar a modo archivado ejecutaremos el siguiente comando:

alter database archivelog;

Resultado :

Database altered.

Volveremos a inciar la base de datos:

alter database open;

Resultado comando:

Database altered.

Archivado automático:
comprobamos el valor del parámetro "log_archive_start", si está a "false" lo pondremos a "true". 

actual del parámetro ejecutaremos el siguiente comando:

show parameter log_archive_start;
Devolverá e:

NAME TYPE VALUE
------------------- -------- --------
log_archive_start boolean FALSE

Modificaremos el parámetro "log_archive_start" a "true" con el siguiente comando:

alter system set LOG_ARCHIVE_START=TRUE SCOPE=spfile;

Resultado comando:

System altered.
Al ejecutar "SCOPE=spfile" haremos que los cambios se guarden .

Para que los cambios tengan efecto es recomendable parar y volver a iniciar la base de datos:

shutdown immediate;
Iniciaremos la base de datos en modo normal:

startup;
Notas:

Para comprobar en qué modo está la base de datos:

select log_mode from v$database;

Resultado:

LOG_MODE
-------------------------
NOARCHIVELOG (está en modo no archivado)

select log_mode from v$database;

LOG_MODE
--------------------
ARCHIVELOG (está en modo archivado)

Otra forma:

archive log list;

Resultado:

Database log mode Archive Mode
Automatic archival Enabled
Archive destination C:/oracle/ora92/RDBMS
Oldest online log sequence 395
Next log sequence to archive 397
Current log sequence 397 
* Para ver el valor parámetro de archivado automático:

show parameter log_archive_start;

NAME TYPE VALUE
------------------- ----------- -----
log_archive_start boolean FALSE
DESACTIVAR EL MODO ARCHIVE LOG

Abriremos la aplicación SQL Plus de Oracle cmd

sqlplus /nolog

Nos conectamos con un usuario con suficientes privilegios a la base de datos Oracle a la que queramos desactivarle el modo Archive Log (ARCHIVELOG), con el comando:

connect usuario/contraseña@NOMBRE_BASE_DATOS as sysdba

Ejecutamos el siguiente comando para desactivar el modo archive log:

alter system archive log stop;

Mostrará :

System altered.

Para comprobar que se ha desactivado correctamente:

archive log list;

Mostrará el siguiente resultado:

Database log mode Archive Mode
Automatic archival Disabled
Archive destination C:/oracle/oradata/bdtest/archive
Oldest online log sequence 70
Next log sequence to archive 72
Current log sequence 72

A continuación os mostramos todo el contenido de la ventana de MS-DOS:

C:>sqlplus /nolog

SQL*Plus: Release 9.2.0.1.0 - Production on Fri aug 13 12:30:36 2015

Copyright (c) 1999, 2014, Oracle Corporation. All rights reserved.

SQL> connect /@BDLOCAL as sysdba;
Connected.
SQL> select log_mode from v$database;

LOG_MODE
------------
NOARCHIVELOG

SQL> show parameter log_archive_start;

NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
log_archive_start boolean FALSE
SQL> alter database archivelog;
alter database archivelog
*
ERROR at line 1:
ORA-01126: database must be mounted EXCLUSIVE and not open for this operation
SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup mount
ORACLE instance started.

Total System Global Area 135338868 bytes
Fixed Size 453492 bytes
Variable Size 109051904 bytes
Database Buffers 25165824 bytes
Redo Buffers 667648 bytes
Database mounted.
SQL> alter database archivelog;

Database altered.

SQL> select log_mode from v$database;

LOG_MODE
------------
ARCHIVELOG

SQL> alter database open;

Database altered.

SQL> show parameter log_archive_start;

NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
log_archive_start boolean FALSE
SQL> alter system set LOG_ARCHIVE_START=TRUE SCOPE=spfile;

Sistema modificado.

SQL> show parameter log_archive_dest

NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
log_archive_dest string
...

SQL> ALTER SYSTEM ARCHIVE LOG STOP;
System altered.
SQL> archive log list;
Database log mode Archive Mode
Automatic archival Disabled
Archive destination C:/oracle/oradata/bdtest/archive
Oldest online log sequence 70
Next log sequence to archive 60
Current log sequence 60

CONSULTAS Y QUERY PARA SYBASE

  • LEVANTAR SERVICIO SYBASE:
$ startserver -f RUN_servername


  • LIBERAR ESPACIO LOG

 dump tran NOMBREDELABASE with no_log
 go

  • AUMENTAR UN DISPOSITIVO

disk resize
name = "NOMBREDELSEGMENT",
size = "424M"
go

USE master
go
ALTER DATABASE NOMBREDELABASE
LOG ON NOMBREDELSEGMENT='524M'
go

  • MODIFICAR A BULLCOPY

sp_dboption BASE
"select into/bulkcopy", true
 go
 use BASE
 go
 checkpoint
 go

  • CHECK PARA VALIDAR Y CORREGIR TABLAS
dbcc checktable  <Nombredelatabla>

CONSULTAS IMPORTANTES PARA UN BASE ORACLE !!!!

select * from dba_jobs_running
•• Consulta Oracle SQL sobre la vista que muestra el estado de la base de datos

select * from v$instance
•• Consulta Oracle SQL que muestra si la base de datos está abierta

select status from v$instance
•• Consulta Oracle SQL sobre la vista que muestra los parámetros generales de Oracle

select * from v$system_parameter
•• Consulta Oracle SQL para conocer la Versión de Oracle

select value from v$system_parameter where name = 'compatible'
•• Consulta Oracle SQL para conocer la Ubicación y nombre del fichero spfile

select value from v$system_parameter where name = 'spfile'
•• Consulta Oracle SQL para conocer la Ubicación y número de ficheros de control

select value from v$system_parameter where name = 'control_files'
•• Consulta Oracle SQL para conocer el Nombre de la base de datos

select value from v$system_parameter where name = 'db_name'
•• Consulta Oracle SQL sobre la vista que muestra las conexiones actuales a Oracle
   Para visualizarla es necesario entrar con privilegios de administrador

select osuser, username, machine, program
from v$session
order by osuser
•• Consulta Oracle SQL que muestra el número de conexiones actuales a Oracle
   agrupado por aplicación que realiza la conexión

select program Aplicacion, count(program) Numero_Sesiones
from v$session
group by program
order by Numero_Sesiones desc
•• Consulta Oracle SQL que muestra los usuarios de Oracle conectados y el número de sesiones por usuario

select username Usuario_Oracle, count(username) Numero_Sesiones
from v$session
group by username
order by Numero_Sesiones desc

•• Consulta Oracle SQL que muestra propietarios de objetos y número de objetos por propietario

select owner, count(owner) Numero
from dba_objects
group by owner
•• Consulta Oracle SQL sobre el Diccionario de datos
   (incluye todas las vistas y tablas de la Base de Datos)

select * from dictionary
•• Consulta Oracle SQL que muestra los datos de una tabla especificada
   (en este caso todas las tablas que lleven la cadena "XXX")

select * from ALL_ALL_TABLES where upper(table_name) like '%XXX%'

•• Consulta Oracle SQL que muestra las descripciones de los campos de una tabla especificada
   (en este caso todas las tablas que lleven la cadena "XXX")

select * from ALL_COL_COMMENTS where upper(table_name) like '%XXX%'


•• Consulta Oracle SQL para conocer las tablas propiedad del usuario actual

select * from user_tables
•• Consulta Oracle SQL para conocer todos los objetos propiedad del usuario conectado a Oracle

select * from user_catalog
•• Consulta Oracle 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
•• Consulta Oracle SQL para conocer los productos Oracle instalados y la versión

select * from product_component_version
•• Consulta Oracle SQL para conocer los roles y privilegios por roles

select * from role_sys_privs
•• Consulta Oracle SQL para conocer las reglas de integridad y columna a la que afectan

select constraint_name, column_name from sys.all_cons_columns
•• Consulta Oracle SQL para conocer las tablas de las que es propietario un usuario, en este caso "xxx"

SELECT table_owner, table_name from sys.all_synonyms where table_owner like 'xxx'
•• Consulta Oracle SQL como la anterior, pero de otra forma más efectiva
   (tablas de las que es propietario un usuario)

SELECT DISTINCT TABLE_NAME
FROM ALL_ALL_TABLES
WHERE OWNER LIKE 'HR'
•• Parámetros de Oracle, valor actual y su descripción

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
•• Consulta Oracle SQL que muestra los usuarios de Oracle y datos suyos
   (fecha de creación, estado, id, nombre, tablespace temporal,...)

Select * FROM dba_users
•• Consulta Oracle SQL para conocer tablespaces y propietarios de los mismos

select owner, decode(partition_name, null, segment_name,
segment_name || ':' || partition_name) name,
segment_type, tablespace_name,bytes,initial_extent,
next_extent, PCT_INCREASE, extents, max_extents
from dba_segments
Where 1=1 And extents > 1 order by 9 desc, 3
•• Últimas consultas SQL ejecutadas en Oracle y usuario que las ejecutó

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
•• Consulta Oracle SQL para conocer todos los tablespaces

select * from V$TABLESPACE
•• Consulta Oracle SQL para conocer la memoria Share_Pool libre y usada

select name,to_number(value) bytes
from v$parameter where name ='shared_pool_size'
union all
select name,bytes
from v$sgastat where pool = 'shared pool' and name = 'free memory'
•• Cursores abiertos por usuario

select b.sid, a.username, b.value Cursores_Abiertos
from v$session a,
v$sesstat b,
v$statname c
where c.name in ('opened cursors current')
and b.statistic# = c.statistic#
and a.sid = b.sid
and a.username is not null
and b.value >0
order by 3
•• Consulta Oracle SQL para conocer los aciertos de la caché (no debería superar el 1 por ciento)

select sum(pins) Ejecuciones, sum(reloads) Fallos_cache,
trunc(sum(reloads)/sum(pins)*100,2) Porcentaje_aciertos
from v$librarycache
where namespace in ('TABLE/PROCEDURE','SQL AREA','BODY','TRIGGER');
•• Sentencias SQL completas ejecutadas con un texto determinado en el SQL

SELECT c.sid, d.piece, c.serial#, c.username, d.sql_text
FROM v$session c, v$sqltext d
WHERE c.sql_hash_value = d.hash_value
and upper(d.sql_text) like '%WHERE CAMPO LIKE%'
ORDER BY c.sid, d.piece
•• Una sentencia SQL concreta (filtrado por sid)

SELECT c.sid, d.piece, c.serial#, c.username, d.sql_text
FROM v$session c, v$sqltext d
WHERE c.sql_hash_value = d.hash_value
and sid = 105
ORDER BY c.sid, d.piece
•• Consulta Oracle SQL para conocer el tamaño ocupado por la base de datos

select sum(BYTES)/1024/1024 MB from DBA_EXTENTS
•• Consulta Oracle SQL para conocer el tamaño de los ficheros de datos de la base de datos

select sum(bytes)/1024/1024 MB from dba_data_files
•• Consulta Oracle SQL para conocer el tamaño ocupado por una tabla concreta sin incluir los índices de la misma

select sum(bytes)/1024/1024 MB from user_segments
where segment_type='TABLE' and segment_name='NOMBRETABLA'
•• Consulta Oracle SQL para conocer el tamaño ocupado por una tabla concreta incluyendo los índices de la misma

select sum(bytes)/1024/1024 Table_Allocation_MB from user_segments
where segment_type in ('TABLE','INDEX') and
(segment_name='NOMBRETABLA' or segment_name in
(select index_name from user_indexes where table_name='NOMBRETABLA'))
•• Consulta Oracle SQL para conocer el tamaño ocupado por una columna de una tabla

select sum(vsize('NOMBRECOLUMNA'))/1024/1024 MB from NOMBRETABLA
•• Consulta Oracle SQL para conocer el espacio ocupado por usuario

SELECT owner, SUM(BYTES)/1024/1024 MB FROM DBA_EXTENTS
group by owner
•• Consulta Oracle SQL para conocer el espacio ocupado por los diferentes segmentos
   (tablas, índices, undo, rollback, cluster, ...)

SELECT SEGMENT_TYPE, SUM(BYTES)/1024/1024 MB FROM DBA_EXTENTS
group by SEGMENT_TYPE
•• Consulta Oracle SQL para obtener todas las funciones de Oracle: NVL, ABS, LTRIM, ...

SELECT distinct object_name
FROM all_arguments
WHERE package_name = 'STANDARD'
order by object_name
•• Consulta Oracle SQL para conocer el espacio ocupado por todos los objetos de la base de datos,
   muestra los objetos que más ocupan primero

SELECT SEGMENT_NAME, SUM(BYTES)/1024/1024 MB FROM DBA_EXTENTS
group by SEGMENT_NAME
order by 2 desc