¿Quién no tiene su chuleta de consultillas útiles que se suelen utilizar en el día a día, y en nuestras aventuras y desventuras con la base de datos?
Listado de consultas SQL de Oracle, la mayoría sobre las vistas del diccionario de Oracle, para obtener información sobre objetos de la base de datos propios o a los que tiene permisos de acceso si se trata de un usuario normal, y sobre objetos de cualquier usuario si el usuario es DBA.
La idea es crear un pequeño un repositorio para poder consultar desde cualquier lugar para facilitarnos la vida, o sacarnos de algún que otro apuro.
Consultas para usuarios de Oracle
Consultas que se pueden hacer a nivel de usuario sin privilegios de administrador, suelen ir también sobre el diccionario de datos de Oracle, pero retornan datos de los objetos a los que el usuario tiene acceso
-- Consulta Oracle SQL sobre el Diccionario de datos -- Con esta vista se consultan los nombres de las tablas o vistas del diccionario a las que el usuario tiene acceso, útil para saber dónde buscar información sobre objetos a los que el usuario tiene acceso select * from dictionary where table_name like '%TABLES%'
-- Consulta Oracle SQL que muestra los metadatos de la/s tabla/s especificada/s por nombre -- (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 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%' -- 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 obtener todas las funciones de Oracle: NVL, ABS, LTRIM, ... SELECT distinct object_name FROM all_arguments WHERE package_name = 'STANDARD' order by object_name
Consultas para DBAs de Oracle
Consultas sobre vistas de sistema, normalmente requieren permisos de DBA o administrador
-- 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
-- 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 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 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 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 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 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
-- 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
Libros de Administración Oracle (DBA) y PL/SQL
¿Quieres profundizar más en PL/SQL de Oracle o en administración de bases de datos Oracle? Puedes hacerlo consultando alguno de estos libros de Oracle.
- Versión para impresión
- Inicie sesión para enviar comentarios
tablespaces en oracle
Subido por estyom (no verificado) el 2 Marzo, 2010 - 02:07
Saludos a todos.. Tengo una pregunta, en esta página se indica como ver
los datos de un tablespace desde Oracle Enterprise Manager,
pero ¿Se lo puede hacer via comandos desde SQL * Plus?..
En este mismo tema tienes la
Subido por Carlos el 4 Marzo, 2010 - 00:24
En respuesta a tablespaces en oracle por estyom (no verificado)
En este mismo tema tienes la respuesta. Entre las consultas SQL de la entrada inicial hay varios que consultan datos de tablespaces, que se encuentran en vista dba_tablespaces.
Otro ejemplo podría ser una query como esta:
select TABLESPACE_NAME, INITIAL_EXTENT, NEXT_EXTENT, MIN_EXTENTS, MAX_EXTENTS, PCT_INCREASE, STATUS, CONTENTS, LOGGING, FORCE_LOGGING
from dba_tablespaces
where TABLESPACE_NAME like 'mitablespace%';
Para comparar dentro de un
Subido por Carlos el 24 Marzo, 2007 - 22:41
Para comparar dentro de un DECODE con parte de un texto del contenido de un campo, es decir, para poder utilizar un like u otras funciones en lugar de la igualdad que toma por defecto el DECODE se puede hacer lo siguiente:
Cuando un tablespace se queda
Subido por Carlos el 2 Noviembre, 2007 - 11:21
Cuando un tablespace se queda sin espacio se puede ampliar creando un nuevo fichero de datos, o ampliando uno de los existentes.
Para consultar el espacio ocupado por cada datafile se puede utilizar la consulta de la lista anterior:
•• 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
Una vez que localizamos el datafile que podríamos ampliar ejecutaremos la siguiente sentencia para hacerlo:
ALTER DATABASE
DATAFILE '/db/oradata/datafiles/datafile_n.dbf' AUTOEXTEND
ON NEXT 1M MAXSIZE 4000M
Con esta sentencia, el datafile continuaría ampliándose hasta llegar a un máximo de 4Gb.
Si preferimos crear un nuevo datafile porque los que tenemos ya son demasido grandes, una sentencia que podríamos utilizar es la siguiente:
ALTER TABLESPACE "MiTablespace"
ADD
DATAFILE '/db/oradata/datafiles/datafile_m.dbf' SIZE
100M AUTOEXTEND
ON NEXT 1M MAXSIZE 1000M
Crearíamos un nuevo fichero de datos de 100 Mb, y en modo autoextensible hasta 1000 Mb. Por supuesto, el path especificado debe ser el específico de cada base de datos, y se debe utilizar para todo el proceso un usuario con privilegios de DBA.
Para matar una sesión de
Subido por cfb el 14 Noviembre, 2007 - 13:28
Para matar una sesión de Oracle hay que utilizar, con un usuario con permisos de DBA, el comando
ALTER SYSTEM KILL SESSION 'SID,SERIAL#';
Para obtener el SID y el SERIAL# que necesitamos se puede utilizar la consulta:
SELECT p.*, s.*
FROM v$session s, v$process p
WHERE p.addr(+)=s.paddr
ORDER BY SID
Esta consulta devolvería los datos de todas las sesiones abiertas, se pueden restringir los resultados a las sesiones que interesen añadiendo condiciones en el where.
Si el número de sesiones que hay que eliminar es elevado, se puede utilizar esta misma consulta para crear las sentencias necesarias dinámicamente:
SELECT 'alter system kill session '''||s.sid||','||p.serial#||''';'
FROM v$session s, v$process p
WHERE p.addr(+)=s.paddr
AND s.username='USER'; (por ejemplo)
Sobretodo cuidado con la condición que se incluye en el where, ya que si no se especificara nada, por ejemplo, se matarían todas las sesiones de la base de datos.
Para crear un script con estas sentencias consultar Construcción de scripts con ayuda del diccionario
Gente, capas que hay gente
Subido por betorey_24 (no verificado) el 17 Julio, 2008 - 22:37
En respuesta a Para comparar dentro de un por Carlos
Gente, capas que hay gente que ya sabia de estas funciones pero bueno simplemente para dejarlo plasmado en alguna pagina y le pueda llegar a ser de gran utilidad a todo el mundo. Lo que voy a postear me llevo un tiempo encontrarlo y la idea con esto es lograr que sea mas facil encontrarlo y ademas que funcione porque hay mucha basura dando vueltas en la internet.
una funcion muy util que recien encontre hoy dia es: SYS_CONTEXT.
NOTA: USERENV es un nombre que describe la sesion actual y con ella y la funcion sys_context se puede conseguir:
estas dos listas digamos son utiles como para ver las que hay y luego investigar un poco mas como se utilizan en internet.
•• Envio de e-mail a multiples usuarios mediante la utilidad UTL_SMTP.
Otra cosa que me costo mucho encontrar y en definitiva me lo termino contando un amigo del trabajo es como utilizar el paquete UTL_SMPT para mandar un mail a multiples recipientes. (a varias personas)
Mi idea es unicamente explicar este problema, como usarlo se los dejo para que lo investiguen que no es muy dificil.
si se tiene los mails en un VARCHAR de la siguiente manera
alguien@xxx.com;alguien1@xxx.com;alguien2@xxx.com;alguien3@xxx.com;alguien4@xxx.com
una vez hecho los pasos :
hay que definir el recipiente con la funcion utl_smtp.rcpt(); tener en cuenta que este recipiente se va a instanciar en nuestro caso 5 veces (una vez por cada e-mail y no todos en uno solo OJO!)
para cortar los mails concatenados en un VARCHAR y cumplir el proposito anterior pueden usar este procesos que me toco hacer que hace lo anteriormente descrito.
se instancia este procesos pasandole la conexion de mail y la lista de mails osea:
p_rec_mail VARCHAR2(300) := alguien@xxx.com;alguien1@xxx.com;alguien2@xxx.com;alguien3@xxx.com;alguien4@xxx.com;
instancia --> Pi_Prepare_Recip_Mail( g_mail_conn , p_rec_mail );
En si es dificil de entender y mas de explicar, trate de ser lo mas claro posible. Cualquier duda sobre este tema escriban.
Con esto hay para divertirse un buen rato..... nunca termina de sorprenderme Oracle...
Si hiciste las consultas hace
Subido por Carlos el 21 Abril, 2008 - 23:31
Si hiciste las consultas hace tiempo y no tenías activada la auditoría de Oracle sobre el usuario que las ejecutó no creo que las puedas recuperar.
Para poder saber las sentencias SQL que ha ejecutado un usuario tienes que decir previamente a la base de datos que haga un seguimiento de las mismas, se ha de auditar al usuario.
Es una medida de seguridad, y si se abusa de ella puede llegar a afectar negativamente al rendimiento de la base de datos, por lo que deberías aplicarla sólo si es necesario. Por supuesto, necesitarás un usuario con privilegios de DBA para poder hacerlo.
En el documento Guide to auditing in Oracle applications, elaborado por www.integrigy.com, se explica bastante bien cómo activar la auditoría en bases de datos Oracle y las diferentes opciones que hay.
También puedes consultar la información del tema que hemos abierto sobre auditoría, seguimiento y seguridad en Oracle.
A partir de la versión 10g, con la consola web de administración (Enterprise Manager Console) también tienes la opción de consultar sentencias SQL ejecutadas durante las últimas 24 horas. Seguramente no te solucionará tu actual problema, pero para analizar ejecuciones y problemas más recientes siempre va bien.
How to send e-mail from Oracle
Subido por eliviced (no verificado) el 9 Octubre, 2008 - 18:26
En respuesta a Si hiciste las consultas hace por Carlos
Hola,
solo queria compartir esta pagina que me parece muy interesante sobre como enviar mail desde Oracle
http://www.dba-oracle.com/t_email_mailing_messages_plsql.htm
:-D
Gracias por la aportación,
Subido por Carlos el 15 Octubre, 2008 - 20:53
En respuesta a How to send e-mail from Oracle por eliviced (no verificado)
Gracias por la aportación, pero más arriba betorey_24 ya nos explica cómo enviar mails con Oracle, y en castellano ;)
De todas maneras la página de BC que enlazas es una buena referencia, muchas veces he acabado en ella buscando cómo solucionar algún tema de Oracle.
Cómo seleccionar un determinado número de registros en Oracle
Subido por Carlos el 4 Diciembre, 2008 - 00:46
Para hacer que nuestra consulta nos devuelva sólo los n primeros registros, y no saturar ni servidores ni aplicaciones cliente cuando trabajamos con tablas grandes, en Oracle tan sólo hay que añadir la condición where rownum < n a la sentencia SQL.
Por ejemplo:
SELECT * FROM tabla_ventas
WHERE rownum < 100;
Aunque nuestra tabla de ventas tenga 10.000.000 de registros, esta consulta sólo nos devolverá los primeros 99 que encuentre.
Hola Carlos, he encontrado
Subido por isunza el 21 Diciembre, 2009 - 18:03
Hola Carlos, he encontrado cosas muy interesnates aqui y tambien veo que mucha ayuda, espero me puedas ayudar con un problemita que tengo. Ya tengo listo el proceso que me manda el correo desde oracle a varias persona y con un texto fijo que mando como parametro, pero me falta saber como mandar el resultado de una consulta por el mismo correo ¿Me puedes ayudar?
Gracias.
Estimado, una pregunta,
Subido por oquiroz (no verificado) el 8 Marzo, 2010 - 23:14
Estimado, una pregunta, existira alguna vista o consulta en Oracle que ayude a Saber dentro de las sesiones activas o inactivas cuales son o fueron los ultimos procesos que se ejecutaron (updates, select, delete, etc)? Gracias por tu pronta respuesta! Saludos!
Las sesiones actuales las
Subido por Carlos el 10 Marzo, 2010 - 22:26
En respuesta a Estimado, una pregunta, por oquiroz (no verificado)
Las sesiones actuales las puedes consultar con la vista v$session y las sentencias SQL que se ejecutan con v$sqltext.
Para enlazar estas dos vistas has de utilizar el campo sql_hash_value de la primera y hash_value de la segunda, y luego aplica las condiciones que te interesen.
En los scripts anteriores hay algún ejemplo de consulta de sentencias. Para sacar las sentencias que se están ejecutando podrías hacer algo así:
SELECT c.sid, c.status, d.piece, c.serial#, c.username, d.sql_text
FROM v$session c, v$sqltext d
WHERE c.sql_hash_value = d.hash_value
ORDER BY c.sid, d.piece
La ordenación por los campos sid y piece es importante porque las sentencias están 'troceadas' en diferentes registros.
Hola Carlos, Una consulta.
Subido por eliviced el 5 May, 2010 - 01:06
En respuesta a Para comparar dentro de un por Carlos
Hola Carlos,
Una consulta. Estoy queriendo subir a memoria(buffer_pool keep) ciertas tablas, pero quiero saber que tablas podrian ser, me han dicho que pueden ser las que mas se utilizan, y que sean pequeñas. Por eso queria saber si existe un query para sacar las tablas mas consultadas. O si tu tienes alguna regla de buena practica para subir las tablas a memoria. Muchas gracias de antemano por la respuesta.
Saludos,
Elizabeth
Hola Elizabeth, Lo que
Subido por drakoniano el 5 May, 2010 - 10:26
En respuesta a Hola Carlos, Una consulta. por eliviced
Hola Elizabeth,
Lo que pides si que se puede hacer porque lo hice hace tiempo, pero no encuentro el script que usé :S
Por si te sirve de ayuda era algo relacionado con el LRU(Menos Recientemente Usada) y con el MRU (Mas Recientemente Usada) ambos del Buffer Caché, ya que es aconsejable para tablas pequeñas y consultadas muy frecuentemente y pocas veces modificadas.
Saludos
Las recomendaciones que te
Subido por Carlos el 5 May, 2010 - 11:29
En respuesta a Hola Elizabeth, Lo que por drakoniano
Las recomendaciones que te han dado me parecen correctas, Elizabeth. Sólo comentarte que controles bien la memoria utilizada y esas cosas, todo lo que se haga en memoria es delicado.
Gracias por la aportación, drakoniano, tiene pinta de ser un buen método. A ver si hay suerte y localizas el script..
En la entrada de blog Cómo obtener la lista de tablas con más movimiento (insert, update) en Oracle, il_masacratore publica un script que creo que también puede servir para tus propósitos, sólo te falta sacar también el tamaño de las tablas, y quedarte con las más pequeñas..
Hola, muchas gracias
Subido por eliviced el 6 May, 2010 - 01:49
En respuesta a Las recomendaciones que te por Carlos
Hola,
muchas gracias drakoniano, y Carlos, ya les cuento como me fue, pero si logras encontrar el script seria genial!!!
Gracias
Elizabeth
Hola eliviced, has encontrado
Subido por Sergio Aguirre (no verificado) el 20 Octubre, 2010 - 17:03
En respuesta a Hola Carlos, Una consulta. por eliviced
Hola eliviced, has encontrado algo al respecto sobre tu pregunta. Gracias. Saludos
Hola amigos, alguien sabe que
Subido por Anonim. (no verificado) el 5 Noviembre, 2010 - 06:57
Hola amigos, alguien sabe que software se puede usar para ver graficamente el contenido de un paquete es decir :
el paqueteI tiene dos procesos: "proceso1","proceso2"; el proceso1 contiene: 3 Cursores y presenta 3 funciones o algo asi, cuando de un click a cada objeto que compone el paquete desplegar el cuerpo del codigo.
help me pls.
saludos
Hola, el PL/SQL Developer, te
Subido por Luiyie (no verificado) el 5 Noviembre, 2010 - 15:45
En respuesta a Hola amigos, alguien sabe que por Anonim. (no verificado)
Hola, el PL/SQL Developer, te puede servir, no es gratuito, pero te lo puedes bajar de taringa.com
Saludos.
Usa Oracle SQL Developer, es
Subido por drakoniano el 12 Noviembre, 2010 - 11:40
Usa Oracle SQL Developer, es gratuito y te lo puedes descargar desde la página de Oracle.
Yo lo uso y la verdad es que le veo algunos errores bastante considerables como por ejemplo
que no se pueda abrir dos sesiones a la vez o que aunque canceles una consulta, a veces,
no se cancela pero para lo que quieres te vale de sobra.
Complementando un poco la
Subido por OMARE el 8 Diciembre, 2010 - 17:07
Complementando un poco la información espero les sirva esto.
MUESTRA LOS ROLES ASIGNADOS AL USUARIO ACTUAL
SELECT granted_role "Rol", admin_option "Admin" FROM user_role_privs;
MUESTRA LOS PRIVILEGIOS A NIVEL SISTEMA DEL USUARIO ACTUAL
SELECT privilege "Privilegio", admin_option "Admin" FROM user_sys_privs;
VERIFICAR LOS ROLES DE CUALQUIER USUARIO DE LA DB, CONECTADO COMO SYS O DBA
SELECT * FROM DBA_ROLE_PRIVS
Saludos
Hola Carlos.. A lo mejor tu
Subido por ABEL el 3 Febrero, 2011 - 22:57
Hola Carlos.. A lo mejor tu me puedes ayudar, se que hay una combinacion de memoria para que el porcentaje de aciertos de una base de datos oracle 9i no este muy baja, pero he manejado muchas hipotesis y no he podido rendir mi base de datos a un nivel optimo ( que no baje del 90% del porcentaje de aciertos) actualmente la tengo como en 60%, que puedo hacer para que el porcentaje de aciertos no sea tan bajo..
Te recomiendo aumentar el
Subido por drakoniano el 3 Marzo, 2011 - 13:08
En respuesta a Hola Carlos.. A lo mejor tu por ABEL
Te recomiendo aumentar el database buffer cache. El criterio que sigue para los aciertos es:
Cache Hit Ratio = 1 - (physical reads / (db block gets + consistent gets))
Para saber como esta configurada tu base de datos :
select physical_reads, db_block_gets, consistent_gets name
from v$buffer_pool_statistics;
Si no funciona:
La relación entre paradas para acceder al redo log y accesos en caché.
select name, value
from v$sysstat
where name='redo entries' OR
name = 'redo log space requests';S
Con una relación superior a 1:5.000 es necesario ampliar el tamaño del buffer de redo.
Los aciertos de Library Cache:
select sum(pins-reloads) / sum(pins) from v$librarycache;
Con un valor menor a 95% se recomienda aumentar el tamaño de la Shared Pool.
Los aciertos en el diccionario de datos
select sum(gets), sum(getmisses), (sum(getmisses)/sum(gets))*100
from v$rowcache;
Con un porcentaje de fallos (getmisses) frente al de aciertos (gets) mayor de 10-15% es necesario aumentar la Shared Pool y estudiar las consultas lanzadas para asegurarse de que usan parámetros.
Espero que te sirva
me podrian ayudar con el
Subido por temporal el 19 Abril, 2011 - 22:36
me podrian ayudar con el siguiene scrip en oracle.....
necesito obtener el nombre del primary key y los campos que lo conforman
select constraint_name,
(select column_name from all_cons_columns where constraint_name=p.constraint_name)columna
from all_constraints p
where owner = 'SYS' and
table_name = 'RULE_SET_IEUAC$' and
constraint_type = 'P'
me genera un error cuando la subconsulta genera dos campos
Muy útiles estos
Subido por Juan_Vidal el 31 May, 2011 - 09:23
Muy útiles estos scripts.
Añado uno relativo a consulta de espacio disponible, ya habeís listado alguno, pero este me parece sencillo y de utilidad también:
SELECT SYSDATE AS FECHA_ACT, DEDICADO.TABLESPACE "TABLESPACE", ROUND (DEDICADO.ESPACIO, 2) "ESPACIO DEDICADO (GB)", ROUND (LIBRE.ESPACIO, 2) "ESPACIO LIBRE (GB)", ROUND (DEDICADO.ESPACIO - LIBRE.ESPACIO, 2) "ESPACIO USADO (GB)", LPAD (ROUND ((LIBRE.ESPACIO / DEDICADO.ESPACIO) * 100, 2) || '%', 6, ' ') "% ESPACIO LIBRE" FROM (SELECT DDF.TABLESPACE_NAME "TABLESPACE", SUM (DDF.BYTES) / 1024 / 1024 / 1024 "ESPACIO" FROM DBA_DATA_FILES DDF WHERE DDF.TABLESPACE_NAME IN ('tablespace1', ' tablespace2') GROUP BY DDF.TABLESPACE_NAME) DEDICADO, (SELECT DFS.TABLESPACE_NAME "TABLESPACE", SUM (DFS.BYTES) / 1024 / 1024 / 1024 "ESPACIO" FROM DBA_FREE_SPACE DFS WHERE DFS.TABLESPACE_NAME IN ('tablespace1', ' tablespace2') GROUP BY DFS.TABLESPACE_NAME) LIBRE WHERE DEDICADO.TABLESPACE = LIBRE.TABLESPACE ORDER BY LIBRE.ESPACIO / DEDICADO.ESPACIO ASCHola, hay alguna manera de
Subido por carlos.a.zambrano el 5 Julio, 2011 - 20:34
En respuesta a Muy útiles estos por Juan_Vidal
Hola,
hay alguna manera de modificar el numero maximo de sesiones de Oracle ??
saludos.
Puedes hacerlo de dos formas:
Subido por drakoniano el 5 Julio, 2011 - 21:08
En respuesta a Hola, hay alguna manera de por carlos.a.zambrano
Puedes hacerlo de dos formas: Modificando el parámetro MAX_SESSIONS vía SQL o en el spfile
Hola !!! Tengo un
Subido por isunza el 5 Julio, 2011 - 20:54
Hola !!!
Tengo un problema que no se como resolver, tengo un procedimiento que le estoy mandando como parametro el nombre de una funcion, dentro del procedimiento quiero que se ejecute la funcion pero no se como ejecutarla, lo que tengo en el codigo es algo asi:
resultado_funcion := p_nombre_funcion;
pero esto solo le asigna a la variable resultado_funcion el nombre de la funcion que tiene el parametro p_nombre_funcion.
Como puedo hacer para que se ejecute la funcion ???
Gracias y Saludos.
Este caso requiere de uso SQL
Subido por Manuel Benitez… (no verificado) el 25 Enero, 2014 - 12:19
En respuesta a Hola !!! Tengo un por isunza
Este caso requiere de uso SQL dinámico con la instrucción EXECUTE IMMEDIATE, ésta es muy potente, ya que permite el uso de parámetros con gran efeciencia. Recuerda revisar el prerequisito de roles para que se pueda ejecutar las funciones o procedimientos.
saludos
mabefa
Muchas gracias , es muy util
Subido por zen719 el 8 Julio, 2011 - 17:02
Muchas gracias , es muy util todo lo que han puesto.
Una consulta, en mi servidor hay dos instancias y las consultas que han dado son a la instancia que
se conecta (por balanceo), hay alguna manera de hacer una consulta que retorne los resultados de ambas instancias?
O algun query para cambiar de instancia al instante sin hacer una nueva conexion? muchas gracias
HOLA, Alguien me puede
Subido por GEORGE_DF el 11 Julio, 2011 - 21:02
HOLA,
Alguien me puede decir como puedo debuguear unas consultas, me estoy iniciando en los scripts, pero me gustaria poder ir viendo como se van tomando los datos de mi consulta,
Gracias.
DIOS LO BENDIGA!!! =D nos
Subido por rodElpoderosoo el 16 Septiembre, 2011 - 18:49
DIOS LO BENDIGA!!! =D nos salvo la vida en un curso de administracion de bases de datos!!
GRACIAS!!!!!!!!!!!
Que tal Carlos! Tengo una
Subido por JDInsane el 5 Octubre, 2011 - 23:09
Que tal Carlos!
Tengo una super duda, sabes tengo un concurrent que al ejecutarse demora demasiado y se me queda colgado por muchas horas, tendrás una consulta con la cual en base al Request ID o algun dato pueda obtener en que consulta esta atorado el proceso o que es lo que esta haciendo?
De antemano te lo agradezco.
Atte. Mane
Mírate las consultas que
Subido por Carlos el 6 Octubre, 2011 - 11:56
En respuesta a Que tal Carlos! Tengo una por JDInsane
Mírate las consultas que obtienen información de la vista v$session, como por ejemplo:
Con estas consultas puedes localizar los identificadores que necesite para investigar despues más a fondo sobre la consulta: cursores abiertos, recursos que consume, etc.
También te puede ir muy bien consultar la información de la vista v$sqlarea, que te muestra información sobre las últimas consultas ejecutadas. Filtrando por usuario, fecha o contenido de la sentencia SQL, si es corta (si no se trunca y has de utilizar otra vista), puedes filtrar información sobre la/s consulta/s que te interesen.
Que barbaro!, muchas gracias
Subido por JDInsane el 7 Octubre, 2011 - 01:43
Que barbaro!, muchas gracias por la información voy a revisar esas consultas.
Saludos cordiales!
Hola espero me puedan ayudar,
Subido por lizgleza el 18 Octubre, 2011 - 19:07
Hola espero me puedan ayudar, necesito un query que pueda sacar los roles que tiene asignado cada usuario, es posible? si asi fuera se los agradeceria-
saludos
Si, claro: select username,
Subido por Juan_Vidal el 18 Octubre, 2011 - 20:17
En respuesta a Hola espero me puedan ayudar, por lizgleza
Muchas gracias :D
Subido por lizgleza el 18 Octubre, 2011 - 21:31
En respuesta a Si, claro: select username, por Juan_Vidal
Muchas gracias :D
Hola, estoy en busca de una
Subido por fgall001 el 16 Enero, 2012 - 17:42
Hola,
estoy en busca de una consulta o herramienta que me permita obtener un listado de todas las tablas que son utilizadas por un Package, Procedure o Function..
Desde ya, gracias por la ayuda..
Saludos
Fermín
Hola Fermín, Echa un vistazo
Subido por Carlos el 18 Enero, 2012 - 01:23
En respuesta a Hola, estoy en busca de una por fgall001
Hola Fermín,
Echa un vistazo a este otro tema del foro de Oracle http://www.dataprix.com/forum/2010/02/obtener-lista-objetos-package-oracle-0
Creo que lo que se comenta te puede servir para buscar objetos de packages utilizando el diccionario de Oracle, o herramientas como Oracle SQL Developer.
Saludos,
Buenas tardes, habra alguna
Subido por Borneo el 21 Junio, 2012 - 01:07
Buenas tardes, habra alguna manera de crear un script de toda la base de datos Oracle 10g ??
Esto es para trasladarla a otro servidor. Por supuesto se puede con un dmp, pero yo quiero hacerlo por medio de un script, si es posible...
Gracias.
Estimado Carlos, Quisiera
Subido por andychile el 26 Agosto, 2013 - 16:35
Estimado Carlos,
Quisiera saber si tu o alguno de los users me pueden ayudar, necesito en una DB saber cuales son los esquemas y cuales son sus respectivas tablas y tablespace y además de eso calcular el espacio que están ocupando cada una. Otra consulta: ¿Todos los usuarios que se crean en oracle tienen asociado un esquema? Si consulto a dba_user puedo diferenciar cual es un usuario con esquema y sin esquema? Gracias por tu sitio que ha sido de mucha ayuda en mi inicio en Oracle. De antemano muchas gracias por tu tiempo. Saludos FranciscoHola Francisco En las
Subido por Carlos el 28 Agosto, 2013 - 00:56
En respuesta a Estimado Carlos, Quisiera por andychile
Hola Francisco
En las consultas de arriba tienes las vistas que te dan la información sobre todas tablas de la base de datos, y también sobre los tablespace y el espacio que ocupan, combinando la información de esas vistas creo que ya puedes sacar la información que necesitas.
En realidad el usuario y el esquema son prácticamente lo mismo. Teóricamente el esquema es el usuario más sus objetos, y se crea cuando creas el primer objeto del usuario. Sobre la diferenciación que comentas, la verdad es que no le veo mucho sentido, supongo que podrías consultar si el usuario tiene algún objeto creado. Para qué la necesitas?
Encontré la consulta que
Subido por andychile el 28 Agosto, 2013 - 05:37
En respuesta a Hola Francisco En las por Carlos
Encontré la consulta que necesito para ver las tablas con sus tablespace y su espacio. La había revisado pero no la había encontrado, después de tu explicación y de leer del tema ya pude asimilar el tema del usuario/esquema por lo que la consulta que te hice arriba al respecto ya está saldada.
Muchas gracias por tu tiempo.
Un abrazo desde Chile!
Saludos
Genial, me alegro de haberte
Subido por Carlos el 28 Agosto, 2013 - 18:53
Excelente recopilación, me ha
Subido por Edwin Rivas (no verificado) el 6 Septiembre, 2013 - 00:24
Buenas, Requiero eliminar
Subido por ba_ca el 30 Septiembre, 2013 - 23:22
Buenas,
Requiero eliminar o revocar el permiso PUBLIC de los paquetes de DBA_TAB_PRIVS (según las mejores prácticas) con la siguiente consulta ejemplifico un SELECT para verificar el dato:
SELECT *FROM DBA_TAB_PRIVS WHERE TABLE_NAME= 'DBMS_RANDOM' AND GRANTEE='PUBLIC';
Así lo revoco (consulta x): REVOKE EXECUTE ON DBMS_RANDOM FROM PUBLIC;
Preguntas:
1. Pero la base de datos Oracle se reinicia cuando lo intento revocar, a que se debe?
2. Cómo podría ejecutar un ALTER para que sea restringido dicho paquetes? o con solo ejecutar la consulta x por default se vuelve restringido el paquete?
Les agradezco las respuestas, por cierto toda la información de arriba me ha servido mucho.
Muchas gracias
Saludos,
Estimado, agradecería puedas
Subido por Rafael_25 (no verificado) el 3 Octubre, 2013 - 01:37
Rafael, no acabo de entender
Subido por Carlos el 4 Octubre, 2013 - 17:51
En respuesta a Estimado, agradecería puedas por Rafael_25 (no verificado)
buenos dias una pregunta, hay
Subido por Anonimo (no verificado) el 4 Octubre, 2013 - 17:26
Para localizar el path del
Subido por Carlos el 4 Octubre, 2013 - 17:59
En respuesta a buenos dias una pregunta, hay por Anonimo (no verificado)
Para localizar el path del fichero Init.ora puedes probar con alguna de estas opciones:
SQL> show parameter ifile; SQL> select value from v$parameter where name = 'ifile';Hola agradeciendo la buena
Subido por Nelson quintanilla (no verificado) el 7 Octubre, 2013 - 17:35
Hola yo tengo diversas
Subido por Anonimo (no verificado) el 2 Noviembre, 2013 - 20:55
Hola Carlos! quisiera ver si
Subido por Jorge Basilico (no verificado) el 6 Noviembre, 2013 - 14:04
Saludos, este tema me ha
Subido por Pomball (no verificado) el 18 Noviembre, 2013 - 17:22
Saludos, ya encontré como
Subido por Pomball (no verificado) el 18 Noviembre, 2013 - 21:30
Hola Pomball, te paso una
Subido por Jorge Basilico (no verificado) el 20 Noviembre, 2013 - 14:53
Buenas tardes, Estoy haciendo
Subido por Cessar (no verificado) el 22 Noviembre, 2013 - 20:13
Buenas noches, mi pregunta es
Subido por Alexrp (no verificado) el 29 Noviembre, 2013 - 06:35
Si te he entendido bien, lo
Subido por Carlos el 29 Noviembre, 2013 - 18:34
En respuesta a Buenas noches, mi pregunta es por Alexrp (no verificado)
Si te he entendido bien, lo que puedes hacer es comparar con la concatenación de los dos campos. Algo así:
select * from tabla1 where cd_Grupo in (select cd_Grupo_or || cd_Grupo_be from tabla2);Saludos,
auxilio carlos esta consulta
Subido por Karol1819 (no verificado) el 16 Diciembre, 2013 - 15:05
Bueno, las agrupaciones
Subido por Carlos el 16 Diciembre, 2013 - 22:29
En respuesta a auxilio carlos esta consulta por Karol1819 (no verificado)
Disculpa CArlos que te saque
Subido por marcelom940 el 18 Agosto, 2014 - 23:17
En respuesta a Bueno, las agrupaciones por Carlos
Disculpa CArlos que te saque del tema, pero hace unos días un DBA me recupero el contenido de una tabla, desde don el dijo, las areas de UNNDO, como puedo recu´perar data de esas areas?, de ante manos muchas gracias por tu gentil respuesta.
Buenos tardes como puedo
Subido por Walter_JuanR (no verificado) el 28 Diciembre, 2013 - 23:56
Por favor lo que necesito es
Subido por jfernando (no verificado) el 27 Noviembre, 2014 - 17:22
Por favor lo que necesito es leer los archivos de un directorio y guardar los nombres de los archivos en otro archivo para luego trabajar con los datos del archivo creado. Ademas luego de haber leído los archivos necesito cambiar su nombre a manera de tener un estado de archivos leídos y no leídos aun.
Gracias si alguien me puede echar una mano.
Como podria consultar desde
Subido por Anonimo (no verificado) el 13 Diciembre, 2014 - 00:01
Como podria consultar desde plsql el tamaño de un archivo que se encuentra en una ruta de mi maquina.
Saludos
Carlos buenos días, quisiera
Subido por Patric (no verificado) el 17 May, 2015 - 01:07
Hola Patric No acabo de ver
Subido por Carlos el 20 May, 2015 - 09:38
En respuesta a Carlos buenos días, quisiera por Patric (no verificado)
Hola Patric
No acabo de ver bien el orden. ¿Primero alterar el campo y luego vaciarlo? Si el campo tiene datos creo que te dará error. Te copio un ejemplo del foro de la OTN de un método para cambiar el tipo de datos de un campo apoyándote en otro campo auxiliar:
SQL> create table "USER" (UserId varchar2(5))
Table created.
SQL> insert into "USER" values ('12345')
1 row created.
SQL> alter table "USER" add (UserId_tmp number(5))
Table altered.
SQL> update "USER" set userid_tmp=userid
1 row updated.
SQL> alter table "USER" set unused column userid
Table altered.
SQL> alter table "USER" rename column userid_tmp to userid
Table altered.
SQL> alter table "USER" drop unused columns
Table altered.
SQL> desc "USER"
TABLE USER
Name Null? Type
----------------------------------------- -------- ----------------------------
USERID NUMBER(5)
Otra opción que te podría funcionar más rápido, si tienes espacio y no hay muchas restricciones sobre la tabla, es utilizar como apoyo una tabla entera en lugar de un campo en la misma tabla. Tendrías que hacer una copia de la tabla original, y después truncar la original, modificar el tipo de datos del campo con un alter, y finalmente hacer un insert desde la copia con un TO_CHAR para el campo que quieres cambiar de tipo.
De todas maneras, yo haría igualmente el backup de la tabla que vas a modificar.
Buenas tardes carlos o
Subido por Luis Sanchez (no verificado) el 4 Marzo, 2016 - 21:02
En respuesta a Hola Patric No acabo de ver por Carlos
Buenas tardes carlos o cualquier que me pueda colaborar le explico con un ejemplo tengo muchos procedimiento que se manejan en form 10g y otros desde php, resulta que hay algun procedimiento no se cual que me esta borrando unos datos en una tabla me gustaria saber si esto es posible y como
quiero hacer un trigger que me diga que usario la fecha y que procedmiento esta invocando sea el insert el update o delete de una tabla
yo ya he hecho trigger y guarda datos normal cuando inserta actualiza o borra y guardo lo que habia antes o despues el usuario que lo hizo y la fecha hasta aqui todo perfecto, pero hay una forma de saber que procedimiento o funcion fue el que invoca la tabla aaaa de modo que el trigger capture cual fue ese procedimiento o funcion (osea el nombre) y lo guardo en mi disparador de la base, de datos de modo que asi puedo saber en donde esta el error y corregirlo mas rapido y no estar mirando todos los ciento de procedimiento que pueda existir y ahi si corregirlo, osea como se dice ir al grano, con ese trigger que quiero hacer es guardar que PROCEDIMIENTO o FUNCION (su nombre) invoca la tabla aaa
muchas gracias a todos estos son mis correos por si me puede escribir le estaria agradecido
asanchez@unet.edu.ve
lalcubo@gmail.com
Estimados, Antes que nada
Subido por Panex (no verificado) el 25 May, 2015 - 20:36
Estimados, Ante todo
Subido por Panex (no verificado) el 26 May, 2015 - 17:17
Hola tengo una duda acerca de
Subido por miguelLlJ (no verificado) el 2 Marzo, 2016 - 17:39
Hola tengo una duda acerca de crear un nuevo esquema en una base de datos.
existe un servidor d base de datos que tiene 3 esquemas (son de 3 docentes) y ha llegado un nuevo docente asi que necesito crear un nuevo esquema pero no se que pasos seguir. En internet encuentro diversas formas y confunde.
manejo este servidor desde la terminal.
hola buenas disculpe como
Subido por Anonimo (no verificado) el 16 Marzo, 2016 - 15:08
hola buenas disculpe como puedo ver un subtotal en una bd.?
Hola, muy interesante tu
Subido por javier bautista (no verificado) el 30 Marzo, 2016 - 00:59
Hola, muy interesante tu sitio, tengo una pregunta que quizas es tonta pero soy nuevo en esto y es la siguiente.
¿Existe una forma de ver que afectaciones tiene la accion de un boton en una aplicacion en la base de datos?
por ejemplo que al dar click en un check y salvar las modificaciones, saber que realizo a nivel base de datos si ejecuto algun procedimiento almacenado?
saludos y disculpa por la pregunta un poco fuera de lugar
Hola Javier Si el botón
Subido por Carlos el 30 Marzo, 2016 - 10:10
En respuesta a Hola, muy interesante tu por javier bautista (no verificado)
Hola Javier
Si el botón ejecuta un procedimiento almacenado puedes revisar el código del procedimiento para comprobar qué es lo que hace, o ejecutar tú directamente el procedimiento desde la base de datos, si estás seguro de que no vas a estropear nada.
Si el procedure es muy complejo, y cuesta seguirlo, puedes al menos buscar las sentencias SQL que incluye y ver sobre qué tablas se hacen inserts, updates o deletes, y consultar después los datos de esas tablas para comprobar qué es lo que ha cambiado.
Saludos,
Como saber con una conslta si
Subido por Franco Ayala (no verificado) el 2 Agosto, 2016 - 18:04
Como saber con una conslta si algun proceso: paquete, procedimiento o funcion esta siendo utilizada por algun usuario
Saludos....
Hola Franco Podrías probar
Subido por Carlos el 5 Agosto, 2016 - 13:49
En respuesta a Como saber con una conslta si por Franco Ayala (no verificado)
Hola Franco
Podrías probar este script que he encontrado en AskTom. Te muestra lo que cada usuario está ejecutando, y podrías adaptarlo buscando en sql_text partes del SQL de los packages o funciones que te interese controlar.
Saludos,
select * from sys.dba_users
Subido por julio azocar (no verificado) el 21 Noviembre, 2016 - 23:16
select * from sys.dba_users order by username como sacar los datos mas ordenados en tablas sale esto
USERNAME USER_ID PASSWORD ------------------------------ ---------- ------------------------------ ACCOUNT_STATUS LOCK_DATE EXPIRY_DA -------------------------------- --------- --------- DEFAULT_TABLESPACE TEMPORARY_TABLESPACE CREATED ------------------------------ ------------------------------ --------- PROFILE INITIAL_RSRC_CONSUMER_GROUP ------------------------------ ------------------------------ EXTERNAL_NAME -------------------------------------------------------------------------------- PASSWORD E -------- -
Hola tengo una consulta como
Subido por David_2080 (no verificado) el 29 Marzo, 2017 - 15:31
Hola tengo una consulta como puedo averiguar dentro de un esquema todas las tablas que ya no se estan usando por ejemplo sacar un listado con todas las temporales creadas por el usuario que ya no se registran o no tienen movimientos por años saludos y gracias.
Hola a todos expertos
Subido por nGen44 (no verificado) el 18 Julio, 2017 - 21:53
Hola a todos expertos DBA,
Necesito llevar a cabo una analisis sobre archivos SQL REDO y deseo encontrar especificamente sobre este REDO datos relacionados a una Columna y Valor que se me han indicado buscar, actualmente mi proceso es muy rudimentario, y busco dentro de todo el REDO posibles coincidencias con el campo.
Select * FROM LOGMINER_MONITOR WHERE (LGMN_SQL_REDO LIKE '%589%' and LGMN_SQL_REDO LIKE '%SEGU466%' ) and LGMN_TIMESTAMP between to_date('03/07/2017 00:00:00','dd/mm/yyyy hh24:mi:ss') and to_date('08/07/2017 23:59:59','dd/mm/yyyy hh24:mi:ss') ORDER BY LGMN_TIMESTAMP DESCSe me solicita buscar específicamente en la columna Historics el Valor 598 y el otro valor de la columna INVDS = SEGU466.
Podrian ayudarme eh dado de topes, ya que no soy nuevo en temas de BD.
Agradecere el apoyo.
Estoy realizando un query
Subido por A0ANJGL (no verificado) el 25 Julio, 2017 - 02:16
Estoy realizando un query donde debo acceder a tablas que esta en otras 2 maquinas con un usuario y password distinto; y no quieren crear un dblink
Quisiera saber en oracle como
Subido por AADH (no verificado) el 7 Diciembre, 2017 - 21:56
Quisiera saber en oracle como extraer solo los atributos que no son nulos. Ejemplo tengo una tabla de trabajo para realizar un update a otra tabla (maestra), los campo son en común, pero solo se actualizarán de la tabla maestra aquellos campos que en la tabla de trabajo esten poblados, es decir debo descartar lo que sean null. Por favor me podrian ayudar??
Estimado, Espero se encuentre
Subido por AADH (no verificado) el 7 Diciembre, 2017 - 22:01
Estimado, Espero se encuentre bien, Quisiera saber la forma de realizar un update de una tabla maestra desde una tabla de trabajo en donde hay campos en común pero solo se actualizarán los campos que no estan null en la tabla de trabajo. ya que asi se registraron.
Buenas tardes! Quisiera saber
Subido por Maryluz HG (no verificado) el 9 Febrero, 2018 - 00:46
Buenas tardes! Quisiera saber cómo consultar los logins de la Base de Datos que no han tenido actividad/conexión en la BD en determinado tiempo con el fin de depurar usuarios inactivos.
Hola, quisiera su ayuda para
Subido por Anonimo (no verificado) el 2 Marzo, 2018 - 02:22
Hola, quisiera su ayuda para saber como hacer que los UPDATE a la tabla "X" se tomen para la base de datos "Y" sin importar desde que base de datos se ejecute o que base de datos tengan como default. La base de datos que utilizo es Oracle SqlDeveloper. Espero puedan ayudarme >_<)
Buenas tardes, gracias por
Subido por katy (no verificado) el 2 Abril, 2018 - 23:39
Buenas tardes, gracias por los tips, me sirvieron de mucho, consulte a otro compañero sobre el tema y me comento que para ver los objetos del usuario actual era mucho mejor consultar a la vista dbaobject, mi pregunta es cual es la diferencia entre consultar a esta vista y a las tablas: user_objects, user_tables,....etc?
Hola katy La diferencia de
Subido por Carlos el 3 Abril, 2018 - 07:50
En respuesta a Buenas tardes, gracias por por katy (no verificado)
Hola katy
La diferencia de cara a consultar información está simplemente en la información que te muestran. Las vistas del diccionario suelen mostrar información cruzada sobre varias tablas, pero si tú tienes suficiente con la información que te da una tabla como las de user_objects o user_tables, o prefieres hacer tu misma una query que haga joins entre esas tablas para sacar la información que necesitas no tienes porqué utilizar las vistas.
Y si la vista ya se ajusta a la info que precisas, pues trabajo que te ahorras :)
Consulta Oracle SQL para
Subido por alexander lopez p. (no verificado) el 18 Abril, 2018 - 22:07
hola Carlos, Muchas gracias,
Subido por Berem el 4 May, 2018 - 01:17
hola Carlos,
Muchas gracias, estas consultas que compartes son un tesoro para mi.
Espero puedas ayudarme con esta cuestión:
¿Cómo saber que usuario creo un objeto (no el owner del objeto), sino el usuario que lanzó la consulta para su creación?
por ejemplo, yo Berem con mi user lanzo el sql: CREATE TABLE SCHEMA_DATA.TABLA_PRUEBA ....
owner = SCHEMA_DATA
object: Table TABLE_PRUEBA
user_que_creo_object: Berem
Existe alguna consulta con la que pueda ver esto?
gracias por tu valioso aporte.
Hola Berem Creo que primero
Subido por Carlos el 4 May, 2018 - 19:25
En respuesta a hola Carlos, Muchas gracias, por Berem
Hola Berem
Creo que primero tienes que activar la auditoría si no está activada para sentencias de creación, y después podrás consultar datos sobre los CREATE que se hayan hecho. Echa un vistazo a este enlace: https://docs.oracle.com/cd/E11882_01/server.112/e10575/tdpsg_auditing.htm
Buen dia. Necesito realizar
Subido por JOSE CUENTAS el 18 Octubre, 2018 - 09:18
Buen dia.
Necesito realizar un ALTER MODIFY a una TABLA GLOBAL TEMPORAL pero Oracle me dice que el recurso está ocupado y no puede ejecutarse.
Pueden ayudarme a identificar las sesiones Activas o Inactivas que tienen la tabla ocupada. lo hice por V$sql_text y V$session me sale cualquier cantidad de sesiones, les doy killer y aun asi el recuroso está ocupado.
Gracias.
Buenas noches; cómo puedo…
Subido por rafo.barona el 10 Agosto, 2021 - 03:29
Buenas noches; cómo puedo obtener la cantidad de registros almacenados en un DATAFILE?
I envision that one of the…
Subido por garysmith el 17 Octubre, 2022 - 12:34
I envision that one of the greatest issues with schools is there are an excessive number of interruptions, a lot of undies raiding, best paper writing service expositions ever crews, and boola what not.
https://t.me/pump_upp - best…
Subido por AlbertTaylor el 18 Enero, 2023 - 20:31