Está en la página 1de 4

¿Por qué

utilizar
paquetes?

Desarrollo de
Aplicaciones
con Bases de
Datos

1
Ventajas del uso de paquetes
Dentro de las ventajas que ofrece el uso de paquetes podemos decir lo
siguiente:

Otorga flexibilidad al momento de diseñar la aplicación:


En el momento de diseñar algún módulo de una aplicación que invoque el
contenido de un paquete, todo lo que necesitaremos en principio es la
información de interfaz entre módulos y en la especificación del paquete.
Puede codificarse y compilarse la especificación sin su cuerpo para
posibilitar que estos módulos que la referencian a estos elementos
declarados puedan compilarse sin errores. De esta manera podremos armar
un “prototipo” de nuestro sistema antes de codificar el detalle de este
(Alcalde, 2017, https://goo.gl/uEZfXZ).

Permite modularizar el diseño de nuestra aplicación:


El uso de paquetes permite agrupar elementos relacionados entre sí (tipos,
variables, procedimientos, funciones) en un único módulo PL/SQL que
llevará un nombre que identifique la funcionalidad del conjunto (Alcalde,
2017, https://goo.gl/uEZfXZ).

Permite ocultar los detalles de implementación:


Pueden especificarse cuáles tipos, variables y subprogramas dentro del
paquete son públicos (visibles y accesibles por otras aplicaciones y
subprogramas fuera del paquete) o privados (ocultos e inaccesibles fuera
del paquete). Por ejemplo, dentro del paquete pueden existir
procedimientos y funciones que serán invocados por otros programas, así
como también otras rutinas de uso interno del paquete que no tendrán
posibilidad de ser accedidas fuera de él. Esto asegura que cualquier cambio
en la definición de estas rutinas internas afectará solo al paquete donde se
encuentran, lo que simplificará el mantenimiento y protegerá la integridad
del conjunto (Alcalde, 2017, https://goo.gl/uEZfXZ).

Agrega mayor funcionalidad a nuestro desarrollo:


Las definiciones públicas de tipos, variables y cursores hechas en la
especificación de un paquete persisten a lo largo de una sesión. Por lo tanto,
pueden ser compartidas por todos los subprogramas o paquetes que se
ejecutan en ese entorno durante esa sesión. Por ejemplo, puede utilizarse
esta técnica (en donde solo se define una especificación de paquete y no un
cuerpo) para mantener tipos y variables globales de todo el sistema (Alcalde,
2017, https://goo.gl/uEZfXZ).

Introduce mejoras al rendimiento:


En relación con su ejecución, cuando un procedimiento o función que está
definido dentro de un paquete es llamado por primera vez, todo el paquete
es ingresado a la memoria. Por lo tanto, posteriores llamadas a este u otros
subprogramas dentro de ese paquete realizarán un acceso a la memoria en
lugar de al disco. Esto no sucede con procedimientos y funciones estándares
(Alcalde, 2017, https://goo.gl/uEZfXZ).
2
Permite la sobrecarga de funciones:
PL/SQL nos permite que varios procedimientos o funciones almacenadas,
declaradas dentro de un mismo paquete, tengan el mismo nombre. Esto es
muy útil cuando necesitamos que los subprogramas puedan aceptar
parámetros que contengan diferentes tipos de datos en diferentes
instancias. En este caso Oracle ejecutará la “versión” de la función o
procedimiento cuyo encabezado se corresponda con la lista de parámetros
recibidos (Alcalde, 2017, https://goo.gl/uEZfXZ).

Es posible modificar el cuerpo de un paquete sin necesidad de alterar por ello la


especificación de este.
Los paquetes pueden llegar a ser programas muy complejos y suelen almacenar gran
parte de la lógica de negocio.

3
Referencias
Alcalde, A. (2014). PL/SQL. Paquetes (Packages). Recuperado de
http://elbauldelprogramador.com/plsql-paquetes-packages/

Reinosa, E., Maldonado, C., Muñoz, E., Damiano, L. y Abrutsky, M. (2012).


Capítulo 4 – Lenguaje Procedimental como extensión de PL/SQL. En Autores,
Base de Datos (pp. 133-154). Buenos Aires, AR: Alfaomega.

También podría gustarte