viernes, 18 de febrero de 2022

Formularios en Oracle APEX basados en llamadas a procedimientos almacenados.

Oracle APEX permite asociar operaciones DML a procedimientos almacenados, ofreciendo al desarrollador la flexibilidad de ir más allá del entorno declarativo permitiendo mejorar el rendimiento de las aplicaciones.

Manos a la obra:
 
1) Ejecutar Oracle SQL Developer.
 
2) Conectarse a un esquema por medio de una conexión de Oracle SQL Developer.
 
3) Seleccionar una tabla, pulsar botón secundario del mouse y seleccionar la opción CREAR API DE TABLA del menú emergente.
 
 
4) Se creará la definición y cuerpo de un paquete desplegándose en una hoja de trabajo, hacer click en Ejecutar
 

5) Ejecutar un navegador web y acceder a su entorno de trabajo en Oracle APEX.

6) Click en Creador de aplicaciones para crear una aplicación o abrir una aplicación existente.

7) Click en Crear Página.
 
 
 
8) Click en Form o Pantalla.
 


9) Agregar una página de tipo Pantalla basada en Procedimiento.
 

 
10) Establecer las páginas de redireccionamiento al submitir y al cerrar la página.
 

 
 11) Seleccionar Crear uan Nueva Entradaa de Navegación.



12) Seleccionar el procedimiento REGIONS_TAPI.INS.




Modificar las etiquetas (asociadas con cada parámetro del procedimeinto), establecer valores por defecto(opcional) y hacer click en  Crear.
 


Resultado de la creación de la página.
 


En la vista de diseño podrá onservarse en la pestaña Process la invocación al procedimiento almacenado.
 

Finalmente, se ejecuta la aplicación y la página tipo Pantalla o Formulario estará lista para ingresar datos. 
 

 




lunes, 14 de febrero de 2022

Como actualizar Oracle 18c XE a Oracle 21c XE en Windows 10

 

El siguiente post presentará las instrucciones para actualizar Oracle 18c XE a Oracle 21c XE en el entorno de Windows 10 en sus diferentes ediciones con excepción de la edición Home.

1) Conectarse a la PDB que se requiere migrar

CONNECT / AS SYSDBA ALTER SESSION SET CONTAINER=CDB$ROOT;

2) Desmontar la base de datos de conexión XEPDB1.

ALTER PLUGGABLE DATABASE XEPDB1 CLOSE;

3) Guardar en un archivo .xml el contenido de la base de datos de conexión XEPDB1

  ALTER PLUGGABLE DATABASE XEPDB1 UNPLUG INTO 'E:\oraclexe\XEPDB1\xepdb1.xml';

4)  Eliminar la base de datos de conexión conservando los archivos de datos.

DROP PLUGGABLE DATABASE XEPDB1 KEEP DATAFILES;
 

 5) Reubicar los archivos de datos en una ubicación temporal E:\oraclexe\XEPDB1\

 C:\copy <INSTALL_DIR_18cXE>\oradata\XE\XEPDB1\*.* E:\oraclexe\XEPDB1\
 
 
 

6) Modificar el archivo .xml cambiando la ruta de  acceso a los archivos de datos por la ruta temporal de los mismos.


 


Nota.- Si dispone de más de una PDB deberá repetir las instrucciones 1 a 6.

7) Desinstalar Oracle 18c XE.

8) Instalar Oracle 21c XE.

9) Crear la base de datos de conexión en base al archivo .xml.

 CONNECT / AS SYSDBA
 CREATE PLUGGABLE DATABASE XEPDB2 USING 'E:\oraclexe\XEPDB1\xepdb1.xml' NOCOPY TEMPFILE REUSE;

10) Actualizar la base de datos de conexión a la última versión.

  ALTER PLUGGABLE DATABASE XEPDB2 OPEN UPGRADE;

 

11) Actualizar la base de datos de conexión o usando el comando  Parallel Upgrade Utility

Antes de submitir el comando, deberá crear la carpeta utility en la unidad C:\

C:\app\Usuario\dbhomeXE\perl\bin\perl C:\app\Usuario\dbhomeXE\rdbms\admin\catctl.pl -u sys -d C:\app\Usuario\dbhomeXE\rdbms\admin -c XEPDB2 -l C:\utility -t catupgrd.sql
 

Salida del script 

Al solicitar la contraseña, ingresar la contraseña del usuario SYSTEM de la base de datos ORACLE.


 12) Abrir la base de datos de conexión.

       ALTER PLUGGABLE DATABASE XEPDB2 OPEN;

 

13)  Recompilar los objetos NO VÁLIDOS(INVALID) de la base de datos.

 C:\app\Usuario\dbhomeXE\perl\bin\perl C:\app\Usuario\dbhomeXE\rdbms\admin\catcon.pl -d C:\app\Usuario\dbhomeXE\rdbms\admin -n 1 -l C:\utlrp -e -b utlrp -c 'XEPDB2' C:\app\Usuario\dbhomeXE\rdbms\admin\utlrp.sql


 14) Conectarse como sys as sysdba y listas las PDBS:

     show pdbs;

CON_ID CON_NAME                       OPEN MODE  RESTRICTED
---------- ------------------------------ ---------- ----------
         2 PDB$SEED                       READ ONLY  NO
         3 XEPDB1                         READ WRITE NO
         5 XEPDB2                         READ WRITE NO

 

 14.1) Cambiar de base de datos a XEPDB2.

     ALTER SESSION SET CONTAINER=XEPDB2;

 

 14.2) Listar los objetos no válidos.

      SELECT COUNT(*), 'Objetos no válidos' 
      FROM ALL_OBJECTS WHERE STATUS status = 'INVALID';
 

 Conclusión

El proceso para migrar desde Oracle 18c XE a 21c XE no es complicado y permitirá que se continúen empleando las PDBS's que se disponía en la versión anterior con sus datos e incluso con Oracle APEX en caso de haberlo instalado.


 

Entrada destacada

Cómo instalar Oracle Database 18c Express Edition para Windows

Oracle Database 18c XE ya está disponible para Windows 64bit, en este post se enseñará como instalar y configurar esta nueva versión en W...