Utilizamos cookies propias y de terceros. [Más información sobre las cookies].
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Wiki
Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Enlace de BD Oracle 12c a BD Oracle 11g
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Enlace de BD Oracle 12c a BD Oracle 11g

Publicar nuevo tema Responder al tema
Foros de discusión » Oracle Database, motor de base de datos profesional   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Enlace de BD Oracle 12c a BD Oracle 11g Responder citando

Hola, tengo un servidor con Oracle 12c montado sobre Linux CentOS 7 y tengo otro servidor con Oracle 11g montado sobre Windows Server 2010 ¿se puede acceder desde el Oracle 12c de Linux al 11g de Windows? ¿cómo se haría? lo que quiero es poder ejecutar sentencias SQL (select) desde el Oracle 12c de Linux de algunas tablas del servidor de Oracle 11g en Windows, esto me facilitaría enormemente varios procesos que ahora tengo que hacer de forma manual.

Gracias de antemano.
MensajePublicado:
Jue Jul 16, 2015 5:52 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Enlace de BD Oracle 12c a BD Oracle 11g Responder citando



Anuncios



varios escribió:
Hola, tengo un servidor con Oracle 12c montado sobre Linux CentOS 7 y tengo otro servidor con Oracle 11g montado sobre Windows Server 2010 ¿se puede acceder desde el Oracle 12c de Linux al 11g de Windows? ¿cómo se haría? lo que quiero es poder ejecutar sentencias SQL (select) desde el Oracle 12c de Linux de algunas tablas del servidor de Oracle 11g en Windows, esto me facilitaría enormemente varios procesos que ahora tengo que hacer de forma manual.

Gracias de antemano.


Sí que es posible y, además, es bastante sencillo. Te indicamos los pasos:

1. Primero verifica que en el equipo Windows Server 2010 con Oracle 11g tienes abierto el puerto 1521 en el cortafuegos (o el puerto que hayas asignado a Oracle 11g).

2. En Oracle 11g del W2010 debes disponer de un usuario con permisos suficientes para usar DBLINK (DATABASE LINK) y este usuario, además, deberá tener permisos para acceso a las tablas que quieras consultar. Por supuesto también debes conocer la contraseña de este usuario.

3. Ya en el servidor con Linux y Oracle 12c, desde SQL*PLus (o cualquier otra consola de gestión de Oracle como Oracle SQL Developer) ejecuta la siguiente sentencia para crear el DBLINK (DATABASE LINK):

Código:

create database link NOMBRE_ENLACE
connect to NOMBRE_USUARIO identified by "CONTRASEÑA"
using 'IP_SERVIDOR_ORACLE_EXTERNO:PUERTO/SID_BD_EXTERNA';


Donde:

* NOMBRE_ENLACE: será el nombre del enlace a base de datos externa (database link). Este nombre es necesario conocerlo para poder ejecutar posteriormente las consultas SQL.

* NOMBRE_USUARIO y "CONTRASEÑA": nombre de usuario y contraseña de la base de datos Oracle externa a la que nos conectaremos. La ejecución de consultas SQL tomará este usuario y sus permisos como base, por lo tanto, este usuario debe tener permisos de acceso a las tablas o vistas que queramos listar.

* IP_SERVIDOR_ORACLE_EXTERNO: IP o nombre DNS (hostname) si lo resuelve del servidor externo con Oracle, en tu caso con Oracle 11g y Windows Server 2010.

* PUERTO: número de puerto de la base de datos Oracle a la que nos conectaremos, por defecto es el 1521.

* SID_BD_EXTERNA: SID de la base de datos externa, el SID es el identificativo y se establece en el proceso de creación de la base de datos. Si no lo conoces puedes obtenerlo desde SQL*Plus, en el servidor W2010, con el comando:

Código:

select * from global_name;


Un ejemplo de DBLINK (DATABASE LINK):

Código:

create database link BD_ORACLE11G
connect to system identified by "123456"
using '192.168.1.100:1521/BDAJPDSOFT';


Una vez creado el enlace a base de datos externa podrás usarlo en cualquier consulta SQL, la forma de usarlo es la siguiente:

Código:

select *
from NOMBRE_TABLA@NOMBRE_ENLACE;


Donde:
* NOMBRE_TABLA: nombre de la tabla o vista a la que queramos acceder de la base de datos externa. Si no es del usuario con el que hemos establecido el DBLINK deberemos usar la nomenclatura nombre_usuario.nombre_tabla.

* NOMBRE_ENLACE: nombre del enlace a base de datos externa (DBLINK o DATABASE LINK), en nuestro ejemplo "BD_ORACLE11G".

Un ejemplo de consulta SQL con DBLINK:

Código:

select fac.numero, fac.importe, fac.fecha
from facturas@BD_ORACLE11G fac;
order by fac.fecha desc


Como ves, los DATABASE LINK, son muy efectivos y sencillos de usar, además, podrás vincular tablas de tu base de datos Oracle 12c con las de Oracle 11g si quisieras.
MensajePublicado:
Jue Jul 16, 2015 6:12 am
Top of PageVer perfil de usuario
Mostrar mensajes de anteriores:   
Todas las horas son GMT - 1 Horas
Publicar nuevo tema Responder al tema
Foros de discusión » Oracle Database, motor de base de datos profesional  

Cambiar a:  
Key
  Puede publicar nuevos temas en este foro
No puede responder a temas en este foro
No puede editar sus mensajes en este foro
No puede borrar sus mensajes en este foro
No puede votar en encuestas en este foro
Visita nuestro nuevo sitio web con programas y contenidos actualizados: Proyecto A