? Artículos técnicos Grupo Danysoft: Introducción InterBase 7 Por Pablo Reyes – Grupo Danysoft enero de 2003 - (902) 123146 www.danysoft.com Lo nuevo en InterBase 7 - Danysoft Internacional Lo nuevo en InterBase 7 Recientemente Borland ha lanzado al mercado InterBase 7, la nueva versión de su base de datos multiplataforma. En este artículo veremos una breve descripción de las novedades más importantes. Tabla de Contenido Soporte para SMP (Symmetric MultiProcessor) ............................................................ 3 Información de actividad en tablas temporales .............................................................. 3 Ejemplos................................................................................................................... 3 Nuevo controlador JDBC tipo 4 .................................................................................... 4 Nuevo tipo de dato: BOOLEAN.................................................................................... 4 Nuevas palabras clave ............................................................................................... 4 SET TERM en ISQL..................................................................................................... 4 Ejemplo .................................................................................................................... 5 Nombres de meta-datos y XSQLDA de 68 bytes........................................................... 5 Nuevas APIs ................................................................................................................. 5 BLOBs y ARRAYS .................................................................................................. 5 Detección de la versión del cliente ............................................................................ 5 Seguridad mejorada para tablas externas ....................................................................... 6 Migración fácil ............................................................................................................. 6 Página 2 de 6 Lo nuevo en InterBase 7 - Danysoft Internacional Soporte para SMP (Symmetric MultiProcessor) InterBase 7 soporta el uso de múltiples procesadores simétricos permitiendo el máximo aprovechamiento del hardware disponible. El soporte para SMP comprende tanto al servidor como a los clientes. En versiones anteriores, InterBase se ejecutaba de forma segura en hardware con varios procesadores utilizando sólo uno de ellos. En esta nueva versión los distintos hilos de ejecución hacen uso de todos los procesadores disponibles mejorando considerablemente el rendimiento global del servidor y de los clientes. Información de actividad en tablas temporales Si bien InterBase siempre ha contado con herramientas para obtener información sobre la actividad del servidor, en esta nueva versión hay aun más información disponible en la forma de tablas temporales del sistema. Estas tablas son creadas para cada conexión a una base de datos y, por defecto, están disponibles sólo para el usuario SYSDBA y para el propietario de la base de datos. Ambos usuarios tienen control total sobre ellas y pueden garantizar privilegios para los demás usuarios pero sólo para realizar consultas. La siguiente lista muestra las nuevas tablas temporales del sistema creadas por InterBase para cada conexión a una base de datos: Nombre TMP$ATTACHMENTS TMP$DATABASE TMP$POOL_BLOCKS TMP$POOLS TMP$PROCEDURES Descripción Una fila por cada conexión a una base de datos Una fila por cada base de datos a la que se está conectado Una fila por cada bloque de memoria en cada "pool" Una fila por cada "pool" de memoria en uso Una fila por cada procedimiento almacenado que fue ejecutado desde que se inició la conexión en uso Una fila por cada relación referenciada desde que se inició TMP$RELATIONS la conexión en uso Una fila por cada sentencia actualmente en ejecución en TMP$STATEMENTS cualquier de las conexión en uso TMP$TRANSACTIONS Una fila por cada transacción que está activa o en estado "limbo" Los usuarios SYSDBA y el propietario de la base de datos pueden actualizar estas tablas para controlar el comportamiento del servidor. Los demás usuarios pueden consultar estas tablas como lo harían con cualquier otra tabla, siempre y cuando los usuarios SYSDBA o el propietario de la base de datos les hayan garantizado los privilegios correspondientes. Ejemplos Para ilustrar las posibilidades que estas tablas ponen a disposición de los administradores y usuarios, a continuación se detallan algunos ejemplos de operaciones típicas que podrían llevarse acabo en situaciones normales: • • • Las diez sentencias SQL que más tiempo han tardado en ejecutarse Las diez transacciones más viejas, es decir, la que más tiempo hace que están activas Las diez tablas con más datos a ser eliminados por el recolector de basura Página 3 de 6 Lo nuevo en InterBase 7 - Danysoft Internacional • • • Los diez procedimientos almacenados que más fueron ejecutados ¿Está la opción "sweep" de la base de datos activada? En caso afirmativo, ¿cuál es su progreso? Asignaciones de "pool" de memoria agrupados por tipo de "pool" Hay casos en los cuales surge la necesidad de tomar medidas luego de haber obtenido la información detallada en los puntos anteriores. Modificando la columna TMP$STATE de algunas de las tablas temporales del sistema es posible realizar tareas como las siguientes: • • • • Finalizar transacciones activas o en estado "limbo" rechazando los cambios realizados (rollback) Finalizar transacciones en estado "limbo" aceptando los cambios realizados (commit) Cerrar la conexión en uso Detener la ejecución de una sentencia que aun no ha finalizado Estos son sólo algunos ejemplos de situaciones que antes eran muy difíciles de resolver y que en esta nueva versión son tan fáciles de resolver como realizar una consulta y luego una actualización. Nuevo controlador JDBC tipo 4 El nuevo controlador JDBC tipo 4 facilita el despliegue de aplicaciones Java que acceden a InterBase. Aun se mantiene el soporte para el controlador JDBC tipo 3. Nuevo tipo de dato: BOOLEAN InterBase 7 soporta el tipo de dato BOOLEAN introducido en el estándar SQL 99. Nombre BOOLEAN Tamaño 32 bits Valores TRUE/FALSE/UNKNOWN Nuevas palabras clave Las siguientes palabras reservadas fueron agregadas: • BOOLEAN • TRUE • FALSE • UNKNOWN SET TERM en ISQL Ya no es necesario utilizar la sentencia SET TERM en ISQL para sentencias SQL para la creación de procedimientos almacenados y disparadores. ISQL puede resolver estas sentencias correctamente sin la necesidad de especificar un carácter de final de sentencia con SET TERM. Página 4 de 6 Lo nuevo en InterBase 7 - Danysoft Internacional Ejemplo CREATE PROCEDURE foo... BEGIN una sentencia; otra sentencia; y una más; END; IBConsole y los componentes InterBase Express aun deben utilizar SET TERM para este tipo de sentencias. Por lo tanto, la vieja funcionalidad de SET TERM aun está disponible para compatibilidad hacia atrás. Nombres de meta-datos y XSQLDA de 68 bytes Los nombres de meta-datos pueden ser de 68 bytes de extensión (en realidad, de 67 bytes más un carácter nulo de terminación). Estos nombres están disponibles en todos los clientes de InterBase y en el nuevo controlador JDBC tipo 4. Están siendo implementados en los componentes basados en dbExpress e InterBase Express y deberían estar disponibles en este momento. La estructura XSQLDA ha sido actualizada para soportar los nombres de meta-datos largos. Nuevas APIs A continuación se detallan las nuevas APIs disponibles en InterBase 7. BLOBs y ARRAYS Diez APIs relacionadas con BLOBs y ARRAYS han sido actualizadas para soportar los nombres de meta-datos largos. En estas nuevas APIs, el campo "desc" apunta a una estructura de descripción actualizada para acomodar los nombres de meta-datos largos. Las nuevas APIs son las siguientes: • • • • • • • • • • isc_array_gen_sdl2() isc_array_get_slice2() isc_array_lookup_bounds2() isc_array_lookup_desc2() isc_array_set_desc2() isc_array_put_slice2() isc_blob_default_desc2() isc_blob_gen_bpb2() isc_blob_lookup_desc2() isc_blob_set_desc2() Detección de la versión del cliente Algunos clientes, principalmente controladores, necesitan averiguar el número de versión de la biblioteca del cliente de InterBase. Hay tres APIs nuevas que permiten hacerlo: • isc_get_client_version() Página 5 de 6 Lo nuevo en InterBase 7 - Danysoft Internacional • • isc_get_client_major_version() isc_get_client_minor_version() Seguridad mejorada para tablas externas Bajo ciertas circunstancias, las tablas externas solían plantear problemas de seguridad. Para solucionarlos, la nueva versión de InterBase impone una serie de condiciones que las tablas externas deben cumplir. Estas condiciones son las siguientes y las tablas externas deben cumplir alguna de ellas: • • La tabla debe estar localizada en el directorio <interbase_home>/ext. InterBase siempre puede encontrar los archivos externos ubicados en este directorio. Si la tabla no está localizada en el directorio <interbase_home>/ext entonces es necesario especificar su localización en el archivo de configuración de InterBase, ibconfig, mediante el parámetro EXTERNAL_FILE_DIRECTORY. Si hay más de una localización para tablas externas entonces se debe crear una entrada con este parámetro para cada una de ellas. Migración fácil Borland ha hecho un gran esfuerzo para que la migración de versiones anteriores a la nueva versión 7 sea lo más fácil posible. En la mayoría de los casos, las bases de datos pueden ser migradas a la nueva versión haciendo una copia de resguardo y recuperándola con el nuevo ODS 11 (On-Disk Structure) disponible en la herramienta gbak de la versión 7. Para migraciones complejas hay documentación disponible junto con la que acompaña al producto. Para más información... Si desea más información sobre InterBase, cursos, precios de producto o de licencias no dude en contactar con info@danysoft.com , o visitar www.danysoft.com. Página 6 de 6