Utilizamos cookies propias y de terceros. Al navegar entendemos que aceptas el uso de cookies. +Info.
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Usuario
· Wiki

Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Error ORA 12162 TNS net service name incorrectly specified
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Error ORA 12162 TNS net service name incorrectly specified

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: Error ORA 12162 TNS net service name incorrectly specified Responder citando

Hola, tengo un servidor de base de dtaos con Linux y Oracle 11g. Estoy intentando lanzar un script para obtener el número de tablas bloqueadas de Oracle, el script lo tengo hecho pero al ejecutarlo aparece este error:

ORA-12162 TNS:net service name is incorrectly specified

El contenido del script es el siguiente:

Código:

echo "set feedback off verify off heading off pagesize 0
select count(*) from v\$lock hk, v\$session bs, v\$lock wk, v\$session ws, v\$sqltext wt where hk.lmode != 0 and hk.lmode != 1 and wk.request != 0 and hk.type$
exit" | $ORACLE_HOME/bin/sqlplus -s usuario/xxx | while read output;
do
echo $output
done


El comando intento ejecutarlo desde otro usuario con:

Código:

su oracle -c "/home/oracle/tablas_bloqueadas.sh"


Desde el usuario "oracle" sí se ejecuta bien, pero desde otro usuario que es donde he de ejecutarlo aparece el error:

ORA-12162 TNS:net service name is incorrectly specified
MensajePublicado:
Mar May 19, 2015 11:46 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error ORA 12162 TNS net service name incorrectly specifi Responder citando



Anuncios



El error que nos comentas es debido a que no está encontrando la variable de entorno $ORACLE_SID, dicha variable debe existir en el usuario que ejecute el comando sqlplus, con el valor del SID de Oracle.

Para establecerla:

Código:

export ORACLE_SID=tu_sid_de_oracle


Ultima edición por alonsojpd el Mar May 19, 2015 12:31 pm, editado 2 veces
MensajePublicado:
Mar May 19, 2015 11:54 am
Top of PageVer perfil de usuario
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Re: Error ORA 12162 TNS net service name incorrectly specifi Responder citando



Anuncios



alonsojpd escribió:
El error que nos comentas es debido a que no está encontrando la variable de entorno $ORACLE_SID, dicha variable debe existir en el usuario que ejecute el comando sqlplus. Para establecerla:

Código:

export ORACLE_SID=tu_sid_de_oracle


Ok, ahora me aparece este otro error:

/home/oracle/tablas_bloqueadas.sh: línea 3: /bin/sqlplus: No existe el fichero o el directorio
MensajePublicado:
Mar May 19, 2015 11:57 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error ORA 12162 TNS net service name incorrectly specifi Responder citando



Anuncios



varios escribió:
Ok, ahora me aparece este otro error:

/home/oracle/tablas_bloqueadas.sh: línea 3: /bin/sqlplus: No existe el fichero o el directorio


También debes tener la variable de entorno $ORACLE_HOME con el valor de la ruta de instalación de Oracle:

Código:

export ORACLE_HOME="/etc/oracle/product/11.0.1"
MensajePublicado:
Mar May 19, 2015 12:00 pm
Top of PageVer perfil de usuario
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: [RESUELTO] Error ORA 12162 TNS net service name incorrectly Responder citando



Anuncios



Genial, así ya me funciona bien.
Tengo otra pequeña cuestión ¿hay alguna forma de poner las variables de entorno en el script para no tener que establecérselas al usuario con el que lo ejecuto?
MensajePublicado:
Mar May 19, 2015 12:29 pm
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: [RESUELTO] Error ORA 12162 TNS net service name incorrec Responder citando



Anuncios



varios escribió:
Genial, así ya me funciona bien.
Tengo otra pequeña cuestión ¿hay alguna forma de poner las variables de entorno en el script para no tener que establecérselas al usuario con el que lo ejecuto?


Sí, puedes añadir las siguientes líneas al principio de tu fichero de scritp:

Código:

ORACLE_HOME=/etc/oracle/product/11.0.1
export ORACLE_HOME
ORACLE_SID=TU_SID_DE_ORACLE
export ORACLE_SID

............

MensajePublicado:
Mar May 19, 2015 12:31 pm
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
Este sitio web NO CONTIENE malware, todos los programas con código fuente aquí. Autor: Alonso Javier Pérez Díaz Google+ Síguenos en Google+