Desarrollo de software

El texto está diseñado para programadores, analistas o técnicos de sistemas que deseen conocer la mecánica de trabajo de las bases de datos a través del uso de una de ellas en concreto: Microsoft SQL Server 2000. Aspectos que se revisan: 1- Conceptos teóricos sobre Bases de Datos. 2- Diseño y modelización de datos tomando como base el modelo Entidad/Relación 3- Generalidades de SQL Server 2000 4- Lenguaje SQL a través de la implementación del mismo en SQL Server 2000 (Transact SQL) 5- Ejemplos de diseño utilizando una herramienta CASE: Power Designor Se requiere como mínimo tener conocimientos del sistema operativo Windows a nivel de usuario. No es imprescindible, aunque si recomendable, conocer fundamentos de programación.

BASES DE DATOS CON SQL SERVER 2000. TRANSACT SQL
JORGE MORATALLA

ADVERTENCIA LEGAL
Todos los derechos de esta obra están reservados a Grupo EIDOS Consultoría y Documentación Informática, S.L. El editor prohíbe cualquier tipo de fijación, reproducción, transformación, distribución, ya sea mediante venta y/o alquiler y/o préstamo y/o cualquier otra forma de cesión de uso, y/o comunicación pública de la misma, total o parcialmente, por cualquier sistema o en cualquier soporte, ya sea por fotocopia, medio mecánico o electrónico, incluido el tratamiento informático de la misma, en cualquier lugar del universo. El almacenamiento o archivo de esta obra en un ordenador diferente al inicial está expresamente prohibido, así como cualquier otra forma de descarga (downloading), transmisión o puesta a disposición (aún en sistema streaming). La vulneración de cualesquiera de estos derechos podrá ser considerada como una actividad penal tipificada en los artículos 270 y siguientes del Código Penal. La protección de esta obra se extiende al universo, de acuerdo con las leyes y convenios internacionales. Esta obra está destinada exclusivamente para el uso particular del usuario, quedando expresamente prohibido su uso profesional en empresas, centros docentes o cualquier otro, incluyendo a sus empleados de cualquier tipo, colaboradores y/o alumnos. Si Vd. desea autorización para el uso profesional, puede obtenerla enviando un e-mail fmarin@eidos.es o al fax (34)-91-5017824. Si piensa o tiene alguna duda sobre la legalidad de la autorización de la obra, o que la misma ha llegado hasta Vd. vulnerando lo anterior, le agradeceremos que nos lo comunique al e-mail fmarin@eidos.es o al fax (34)-915012824). Esta comunicación será absolutamente confidencial. Colabore contra el fraude. Si usted piensa que esta obra le ha sido de utilidad, pero no se han abonado los derechos correspondientes, no podremos hacer más obras como ésta. © Jorge Moratalla, 2001 © Grupo EIDOS Consultaría y Documentación Informática, S.L., 2000 ISBN 84-88457-24-3

Bases de datos con SQL Server 2000. Transact SQL Jorge Moratalla
Responsable editorial Paco Marín (fmarin@eidos.es) Autoedición Magdalena Marín (mmarin@eidos.es) Jorge Moratalla (jmoratalla@eidos.es) Grupo EIDOS C/ Téllez 30 Oficina 2 28007-Madrid (España) Tel: 91 5013234 Fax: 91 (34) 5017824 www.grupoeidos.com/www.eidos.es www.LaLibreriaDigital.com Coordinación de la edición Antonio Quirós (aquiros@eidos.es)

................................................. 21 DISEÑO CONCEPTUAL ........................................................................................................................................................................................................................................................................................................................................... 17 DISEÑO LÓGICO....................................................................................................................................................................................... 24 EL MODELO ENTIDAD / RELACIÓN ............................................................................................................................................................................. 37 PARTICIONAMIENTO HORIZONTAL DE RELACIONES ...................Índice ÍNDICE............................................... 9 DEFINICIÓN DE BASE DE DATOS ............... 36 ETAPAS EN EL DISEÑO LÓGICO....................... 35 INTRODUCCIÓN ............................................................................................................................................................................................................................................................... 10 ARQUITECTURA ANSI/X3/SPARC .......................................... 24 EJEMPLOS PRÁCTICOS DE DISEÑO CONCEPTUAL.............................................................................................................. 10 DEL ENFOQUE TRADICIONAL A LOS SISTEMAS DE BASES DE DATOS ............................................................................................................................................................................ 38 ..... 12 EL MODELO RELACIONAL ...................................................................................................................... 23 ETAPAS DEL DISEÑO CONCEPTUAL ....................................................................................... 23 INTRODUCCIÓN ............................................................................. 15 FASES DEL DISEÑO ...... 9 CONCEPTOS BÁSICOS ..................................................................................... 15 DISEÑO CONCEPTUAL ........................................................................................................................................................................... 12 VISIÓN GENERAL SOBRE EL DISEÑO DE BASES DE DATOS................................................................... 17 DISEÑO FÍSICO..... 5 INTRODUCCIÓN ........................................................................................................................ 35 PASO DEL ESQUEMA CONCEPTUAL AL ESQUEMA LÓGICO ESTÁNDAR ....................................................................................................................... 29 DISEÑO LÓGICO....................................................

........................................................................................................................................ 68 INSTALACIÓN DE SQL SERVER 2000 .................................................................. 79 MODIFICACIÓN DEL ESQUEMA ............................................. 92 EL LENGUAJE DE DEFINICIÓN DE DATOS (DDL) ............... 67 NUEVOS TIPOS DE DATOS ............................................................................................................. 63 ORÍGENES............................................................................................................................... 55 DISEÑO FÍSICO .............................................................................................. 67 SOPORTE PARA VIRTUAL INTERFACE ARCHITECTURE (VIA) ......................................................................................................................................... 49 PROCESO DE DESNORMALIZACIÓN ......................................................................................................................................................................................................................................................................... 85 INTRODUCCIÓN ........ 101 CREACIÓN Y BORRADO DE ÍNDICES ....................................................................................................................................................... 97 TIPOS DE DATOS .................................. 68 SOPORTE PARA CONSULTAS DISTRIBUIDAS ......................................................................................................................................... 58 ORGANIZACIÓN DE FICHEROS ..................... 75 CREAR UN NUEVO DIAGRAMA .......................................... 91 EJECUTANDO UNA CONSULTA ................................................................................................................................................................................................................. 68 REGLAS DE INTEGRIDAD REFERENCIAL EN CASCADA ............................................. 41 PARTICIONAMIENTO MIXTO ........................................... 81 CREAR UNA NUEVA RELACIÓN ............. 65 NUEVAS CARACTERÍSTICAS .................................... 75 INTRODUCCIÓN ....... 57 INTRODUCCIÓN ......................................... 63 ¿QUÉ ES SQL SERVER?...................... 77 RESTRICCIONES E INTEGRIDAD REFERENCIAL ............................................................................... 82 EL ANALIZADOR DE CONSULTAS................................................................................................................ 97 INTRODUCCIÓN ................................................................................................................................................ 85 LAS OPCIONES DE MENÚ .................................................... 66 PARTICIONAMIENTO HORIZONTAL DE RELACIONES Y GESTIÓN DE VISTAS DISTRIBUIDAS .................................................................... 64 LO NUEVO EN SQL-SERVER 2000 ........................................................ 97 CREACIÓN DE TABLAS ....................................................... 68 CARACTERÍSTICAS DE SEGURIDAD Y CIFRADO DE DATOS .................................... 68 NUEVAS CARACTERÍSTICAS DE INDEXACIÓN ...... 57 ESTRATEGIAS EN EL DISEÑO FÍSICO ................................................................................................................................................... 65 INTRODUCCIÓN ............................................................................. 67 FUNCIONES DE USUARIO ............................................................................................................................................................................................................................................................................................................... 101 ................................................................................................................................................................................................................ 59 INTRODUCCIÓN A SQL SERVER ................................................................................. 65 SOPORTE PARA XML ....................................................................................... 99 MODIFICACIÓN DE TABLAS ..... 85 LA BARRA DE HERRAMIENTAS ..................................................................................................................................................................... 64 SQL SERVER E INTERNET .................................................................................................................................................................................................... 44 TEORÍA DE LA NORMALIZACIÓN ............................................................................................................................................................................................................................................................................................... 69 EL MODELO E/R EN SQL-SERVER 2000 ................................................................................................................................................................................... 45 EJEMPLOS PRÁCTICOS DE NORMALIZACIÓN ..........................................PARTICIONAMIENTO VERTICAL DE RELACIONES ...................................................................................................................................................................................... 59 TÉCNICAS PARA EL AUMENTO DE EFICIENCIA .............................................................................................................................................................................................. 58 CONCEPTOS BÁSICOS SOBRE GESTIÓN DE FICHEROS ............................................................................................................................................................ 67 NUEVOS TRIGGERS ................................................................................................................................ 100 BORRADO DE TABLAS . 67 INDEXACIÓN DE VISTAS ....................................................................

.................................................................... 103 LA SENTENCIA CREATE TABLE .............................. 147 LA CLAÚSULA WHERE .................................................................................. 125 INTRODUCCIÓN .................................................................................................................. 148 EL OPERADOR JOIN .................................................................... 140 CARGA DE LA BASE DE DATOS DE EJEMPLO ................................................................................................................................................................................................................................................................................................................................................... 169 INTRODUCCIÓN ..................................... 112 EL LENGUAJE DE MANIPULACIÓN DE DATOS (DML) ............................................ 163 INTRODUCCIÓN ........................................................................................... 127 OPERADOR JOIN ....... 169 7 ........................................... 103 INTRODUCCIÓN ......................................................................................................................................................................................................................................................... 107 LA SENTENCIA DROP TABLE ................................................................................................................................................................................................................................................................................................................................................................................................................................... 119 FUNCIONES ESCALARES PARA SELECT ............ 103 LA SENTENCIA ALTER TABLE ...........................................................................................EJEMPLOS PRÁCTICOS DE USO DEL DDL..................................................... 117 LA CLÁUSULA GROUP BY ......................... 163 LA INTEGRIDAD REFERENCIAL............................................................................................... 164 LA SENTENCIA TRUNCATE TABLE.............................................................................................................................................................................. 151 LA CLAÚSULA GROUP BY ..................................................................................................................................................................................................... 137 SENTENCIAS ITERATIVAS ............................................................................................................................................................................................................................................................................................................................................................................................................................................................................... 157 LA SENTENCIA DELETE ..................................... 125 OPERADOR UNION ........................................................................................................................................................... 125 OPERADOR PROYECCIÓN ................................................................................. 139 SINTAXIS ............................................................................................................................ 122 LA SENTENCIA UPDATE ................................. 123 LA SENTENCIA DELETE ... 143 LA SENTENCIA SELECT......................................................................................................................................................................................................................... 115 LA CLÁUSULA WHERE ........................................................................................................ 157 INTRODUCCIÓN ........................................................................................................ 111 LA SENTENCIA CREATE INDEX............................................................................................... 118 LA CLÁUSULA HAVING .................................................................................................................... 147 INTRODUCCIÓN ................................................................................. 115 LA SENTENCIA SELECT .......................... 154 LA SENTENCIA UPDATE ................................................................................................ 139 INTRODUCCIÓN .................................................................................... 119 LA CLÁUSULA ORDER BY .................... 166 PROCEDIMIENTOS ALMACENADOS Y TRIGGERS ...................................................................................................................................................................... 128 OPERADORES PROPIOS DE TRANSACT SQL ................................................................................ 115 INTRODUCCIÓN ............................................................... 149 LAS FUNCIONES DE AGREGADO ................................................................................................................. 165 EJEMPLOS........................................................................................................................................................................................ 132 VARIABLES GLOBALES..................................................... 112 LA SENTENCIA DROP INDEX................................................. 157 EJEMPLOS......................................................................................................... 123 OPERADORES BÁSICOS Y CONSIDERACIONES DEL LENGUAJE .................................... 138 LA SENTENCIA INSERT.............................................. 119 LA SENTENCIA INSERT ......................... 139 EJEMPLOS.............................................................................................................................................................................................. 135 SENTENCIAS CONDICIONALES..................................................................................................

................................................................................................... 185 EJEMPLOS........................................................................................... 184 RESOLUCIÓN DIFERIDA DE NOMBRES ....................................................................................................................................................................................................................................................................................................................................................................... 217 MODIFICACIÓN DE LAS TABLAS ................................................................. 173 TRIGGERS ......................................... 182 TRIGGERS EN SQL-SERVER 2000 ... 189 REVOCACIÓN DE PRIVILEGIOS ................................. 193 RECOMENDACIONES ................................................ 181 LA SENTENCIA WHILE............................................................................................................................................... 198 PRESENTE Y FUTURO DE LAS BASES DE DATOS ................................ 219 INDICES ..... 203 DISEÑO CONCEPTUAL CON POWER DESIGNOR.............................................. 219 ATRIBUTOS EXTENDIDOS .............................................................................................................. 196 LENGUAJE DE MANIPULACIÓN DE DATOS ..................................................... 193 MANTENIMIENTO DE VISTAS ................................................................................................................................................................................................................................................................... 222 EJEMPLO DE DISEÑO CON POWER DESIGNOR.............................................................................................................................. 180 CONVERSIÓN DE TIPOS............................................................................................................................................................................................................................................................. ELSE................................................... 213 LA RELACIÓN DE HERENCIA................................ 217 PASO DEL ESQUEMA CONCEPTUAL AL ESQUEMA FÍSICO ............................ 195 LENGUAJE DE DEFINICIÓN DE DATOS................ 207 INTRODUCCIÓN ......................... 194 EJEMPLO PRÁCTICO DE IMPLEMENTACIÓN..................................... 191 DENEGACIÓN DE PERMISOS .............. 189 CONCESIÓN DE PRIVILEGIOS ..................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................... 183 LAS TABLAS DELETED E INSERTED .................................................................................................................................. 184 TIPOS DE DESENCADENADORES ........................................................................................................................................................................ 184 LIMITACIONES DE LOS TRIGGERS ..................................................................................... 174 EJEMPLOS PRÁCTICOS DE USO DE PROCEDIMIENTOS ALMACENADOS .................................................................................. 195 INTRODUCCIÓN ............................................................................................................................................................................................................................................ 225 ............................................... 218 COLUMNAS .......................................................................................................................................................... 177 INTRODUCCIÓN ....................................................... 185 SEGURIDAD . 183 INTRODUCCIÓN .............................................. 208 CREACIÓN DE RELACIONES ................................................................................ 172 EXTENDED STORED PROCEDURES .... 170 PROCEDIMIENTOS ALMACENADOS DE SISTEMA............................................................................................................................................................................................................. 207 CREACIÓN DE UNA ENTIDAD ....................................................................... 222 CREACIÓN DE VISTAS .......... 177 LA SENTENCIA IF ....................................................................................................PARÁMETROS POR REFERENCIA ........................................................ 221 RESTRICCIONES.................................................................... 189 INTRODUCCIÓN ..................................................................................................................................................................................................................................................................... 215 DISEÑO FÍSICO CON POWER DESIGNOR ........................................................................................... 179 EJECUCIÓN DINÁMICA DE SENTENCIAS: LA INSTRUCCIÓN EXEC ............................................................................................................................................. 221 TRIGGERS ...... 177 LA SENTENCIA CASE ..

se emplean métodos bien determinados para incluir nuevos datos y para modificar o extraer los datos almacenados". tienen una definición y descripción comunes y están estructurados de una forma particular. 1977). 1982). donde los datos están lógicamente relacionados entre sí. como tal. su finalidad es servir a una aplicación o más. (Martin. "Conjunto estructurado de datos registrados sobre soportes accesibles por ordenador para satisfacer simultáneamente a varios usuarios de forma selectiva y en tiempo oportuno". (Flory. Una base de datos es también un modelo del mundo real y. • • • • . que es utilizado por numerosas personas y cuya organización está regida por un modelo de datos". Existen varias definiciones para responder a esta pregunta: • "Colección de datos interrelacionados almacenados en conjunto sin redundancias perjudiciales o innecesarias. (Conference des Statisticiens Européens. "Colección no redundante de datos que son compartidos por diferentes sistemas de aplicación". "Colección o depósito de datos.Introducción Definición de base de datos La primera pregunta que surge a la hora de comenzar este curso es la siguiente: ¿Qué es una Base de Datos?. 1975). (Howe. "Conjunto de datos de la empresa memorizado en un ordenador. 1983). los datos se almacenan de modo que resulten independientes de los programas que los usan. de la mejor manera posible. debe poder servir para toda una gama de usos y aplicaciones". (Delobel. 1982).

organizados y administrados de una manera flexible de modo que los ficheros puedan ser fácilmente adaptados a nuevas tareas imprevisibles". procesar. junto con la base de datos y con los usuarios. "Colección de datos interrelacionados". deben mantenerse independientes de ellos. y su definición (estructura de la base de datos) única y almacenada junto con los datos. "Colección o depósito de datos integrados. almacenar y recuperar esa información. se ha de apoyar en un modelo de datos. • • • • Del enfoque tradicional a los sistemas de bases de datos Para comprender mejor las diferencias entre los sistemas tradicionales basados en ficheros y los sistemas de bases de datos. Los datos. operados y mantenidos para recoger. debido a la replica de información (la misma información puede estar almacenada en distintos ficheros). mientras que una ocurrencia del esquema es distinta en el transcurso del tiempo. estructurada atendiendo a las relaciones naturales de modo que suministre todos los caminos de acceso necesarios a cada unidad de datos con objeto de poder atender todas las necesidades de los diferentes usuarios". que han de ser compartidos por diferentes usuarios y aplicaciones. provincia y teléfono. • • Como se ha visto. Ocurrencia del esquema: Conjunto de datos que se encuentran almacenados en el esquema en un momento determinado. y otro para la emisión de informes. Supóngase que disponemos de un archivo maestro de clientes con la siguiente información: nombre. (Deen. podemos encontrarnos con los siguientes problemas: • Producción de inconsistencias o incoherencias. Los procedimientos de actualización y recuperación. Sistema de Información: Colección de personas. El esquema no varía mientras no varíe el mundo real que éste describe. registrar. 1988). el concepto de base de datos ha ido cambiando a lo largo del tiempo.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS • "Colección integrada y generalizada de datos. almacenados en soporte secundario (no volátil) y con redundancia controlada. el cual ha de permitir captar las interrelaciones y restricciones existentes en el mundo real. Conceptos básicos • Sistema de Gestión de Base de Datos (SGBD): Conjunto de programas que permiten la implantación. facilitarán la seguridad del conjunto de los datos". constituyen el Sistema de Base de Datos. Esquema de una Base de Datos: Estructura de la Base de Datos. a la cual denominamos esquema. procedimientos y equipos diseñados. (Elsmari y Navathe. comunes y bien determinados. construidos. la estructura de una base de datos. "Conjunto de ficheros maestros. Modelo de datos: Conjunto de conceptos que permiten describir. 10 . dirección. pongamos un ejemplo. añadimos dos ficheros. ciudad. 1985). En la actualidad podemos establecer la definición de base de datos como sigue. El SGBD. 1989). (Frank. acceso y mantenimiento de la base de datos. a distintos niveles de abstracción. uno para la emisión de facturas. Si además de esto.

Mayor valor informativo: El conjunto de los datos almacenados en la BD ofrece un mayor valor informativo. Si en este momento se quiere añadir en número de fax. ya que el control de la información es inherente al propio sistema. implica una menor ocupación de almacenamiento secundario. Algunas de las ventajas que ofrece utilizar un Sistema de Bases de Datos son las siguientes: 1. con el fin de conseguir una mayor eficiencia. así como la modificación de éstos no afecta a la reprogramación de las aplicaciones que los usan. así como el coste de adquisición o mantenimiento del SGBD. los Sistemas de Bases Datos no están exentos de inconvenientes. creyendo que constituyen ya una realidad. que muchas veces no se ven traducidos en la práctica. controlada por el sistema y que no afecta a la redundancia lógica. Reducción del espacio de almacenamiento: La desaparición (o disminución) de redundancias. Implantación larga y difícil: Debido a las causas mencionadas anteriormente. 4. Mejor disponibilidad de datos para los usuarios: Los datos son compartidos por un conjunto de usuarios. • • Malgasto de memoria secundaria (por el mismo motivo). 3. para dar cabida a este cambio. Falta de rentabilidad a corto plazo: Los amplios costes que conlleva la implantación.© Grupo EIDOS 1. 11 . Más adelante veremos cómo se permite una cierta duplicidad de datos. que accede a ellos de forma concurrente. en un sistema de gestión de bases de datos. sino a medio. implica una rentabilidad no a corto. compiladores. o incluso largo plazo. se hace necesario una completa reestructuración de dicho fichero.). cuando no han sido todavía plasmados. Escasa estandarización: Esto supone una dificultad añadida a los usuarios de la base de datos. Introducción. sin mencionar el rediseño del código de la aplicación. 5. Aquí se detallan los más importantes: 1. Desfase entre teoría y práctica: Los constantes avances teóricos en al ámbito de las bases de datos. 5. Mayor eficiencia en la recogida. 2. 6. los datos se recogen y validan una sola vez. A pesar de todas estas ventajas. En cambio. El cambio en los programas no influye en la disponibilidad de los datos. 3. 4. tanto en el equipo físico (adquisición de nuevas instalaciones. siempre que estén autorizados a ello. que la suma de ellos independientemente. se evitan los problemas que puede ocasionar la redundancia. programas. aumentando así la eficiencia. etc. estos problemas no tienen cabida. la implantación de un sistema de base de datos puede convertirse en una tarea larga y complicada. validación e introducción de los datos en el sistema: Al no existir redundancia. unido a las técnicas de compactación. Independencia entre datos y tratamientos. Instalación costosa: La implantación de un sistema de base de datos puede implicar un coste elevado. Coherencia de resultados: Debido a que los datos son almacenados una sola vez. 2. hacen llevarse a engaño a muchos usuarios. o ampliaciones de las existentes) como en el lógico (sistemas operativos.

que es único. Nivel Externo: Es el nivel más cercano a los usuarios. En este nivel. lo que permitirá. y en el se definen los datos tal y como los va a ver este. para evitar cierto tipo de anomalías. su nombre y apellidos. El modelo interno. nombre. etc. apellidos. cuales son los datos. número de éstas. En sus estudios acerca de los SGBD. las estrategias de acceso a los datos. establece el modelo teórico sobre el que están asentados los modelos externos. Por lo tanto. sueldo y categoría. se puede saber a que empleado nos estamos refiriendo. Nivel Conceptual: Proporciona una descripción global del esquema independiente de la estructura física de la base de datos. Las claves se representan subrayando el / los atributo/s que forman parte de ella. y que almacenan información para una determinada entidad. Dichas columnas se denominan atributos. radica en la facilidad y en su amplia base matemática. también deberán definirse las restricciones de uso. las relaciones entre ellos y las restricciones de integridad y confidencialidad. El modelo relacional El modelo más usado. técnicas de compresión de datos. A dichas filas también se las denomina tuplas. Nivel Interno: Nivel más bajo en la abstracción. en dar valores para cada uno de los atributos de la entidad. Así mismo especifica todos los aspectos relacionados con el hardware. es decir. dentro del Comité X3 que se ocupa de ordenadores e informática. denominadas relaciones. El modelo conceptual. 12 . es el modelo relacional. y para cada uno de ellos existirá un valor (cabe la posibilidad de que existan atributos en los que no aparezca ningún valor). que almacena información sobre los empleados de una empresa. Cada usuario puede tener su propio modelo externo. con aquellos datos e interrelaciones que dicho usuario necesite. etc. y por lo tanto el que se estudiará en este curso. como están organizados. Cada una de estas relaciones representa en sus columnas los valores significativos. Cada fila representa la información para cada ocurrencia de una determinada entidad. para cada entidad. 2. que es único. de los que interesa conocer su valor. Cada atributo o conjunto de atributos que identifica unívocamente a cada tupla de la relación se denomina clave. como por ejemplo dispositivos de memoria a usar (tamaño de páginas. propugnaron una arquitectura basada en tres niveles de abstracción: 1. es decir. La información que se desea saber de cada empleado es su código. su sueldo y su categoría. 3. los atributos son cod_empleado. La información se descompondrá. El motivo de que sea éste el modelo más extendido. como ya se ha dicho. o acelerar las consultas / actualizaciones. el atributo cod_empleado es clave de la relación. ya que si se sabe el valor de dicho atributo. El siguiente ejemplo (Figura 1) representa una relación denominada empleado. criptografiado. como ya se verá más adelante. tamaño de los buffers. corresponde a la implementación del modelo conceptual. etc. el poder estructurar o reestructurar las relaciones. o poder acceder a ellos. Describe la estructura almacenamiento físico de los datos. Además. como por ejemplo el derecho a insertar o borrar determinados datos.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Arquitectura ANSI/X3/SPARC ANSI/X3/SPARC es un grupo de estudio del Standard Planning and Requirements Commitee (SPARC) del ANSI (American National Standars Institute).). Dicho modelo se basa en la representación de la información por medio de estructuras tipo tabla.

Introducción.© Grupo EIDOS 1. Figura 1 13 .

.

a la vez que ayuda a alcanzar los dos principales objetivos que tienen las bases de datos: • • Ser una representación fidedigna del mundo real. Un esquema conceptual es una descripción a alto nivel de la estructura de la base de datos. El diseño conceptual parte de la especificación de requerimientos.Visión general sobre el diseño de bases de datos Fases del diseño El diseño de una base de datos suele descomponerse en tres grandes fases (diseño conceptual. lo que permite reducir la complejidad que entraña el diseño. Ser un servidor operacional y eficiente de los datos. independientemente de la elección del equipamiento y del Sistema Gestor de Base de Datos (en adelante referido como SGBD) que se usen para la implementación de la base de datos. La meta del diseño lógico es producir el esquema lógico más eficiente con respecto a las operaciones de consulta y actualización. . lógico y físico). Un esquema lógico es la descripción de la estructura de la base de datos que puede procesarse por un SGBD. Una vez elegido el modelo lógico. El diseño lógico parte del esquema conceptual y genera el esquema lógico. y produce como resultado el esquema conceptual de la base de datos. pueden existir un conjunto de esquemas lógicos equivalentes al mismo esquema conceptual.

posteriormente se pasa del esquema conceptual al modelo de datos propio de SGBD elegido (diseño lógico). los caminos de acceso (índices). Un esquema físico es una descripción de la implementación de la base de datos en memoria secundaria. Por ello. y todos los aspectos relacionados con el diseño físico. describe las estructuras de almacenamiento y los métodos de acceso para acceder a los datos de una manera eficiente. Figura 2.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS El diseño físico toma como punto de partida el esquema lógico y como resultado produce el esquema físico. Figura 3. el diseño físico se genera para un SGBD y un entorno físico determinado. por último se eligen las estructuras de almacenamiento. esquema que proporciona una descripción estable de la base de datos (independiente del SGBD) que se vaya a utilizar. Correspondencia entre el diseño y la arquitectura ANSI/X3/SPARC 16 . Diseño de una base de datos En la Figura 2 se resumen las tres grandes fases del diseño de una base de datos: primero se diseña el esquema conceptual (que se realiza con un modelo conceptual de datos).

con el fin de mejorar la eficiencia de la base de datos. al que se añaden las claves ajenas y otras restricciones de integridad. Consiste en ir refinando sucesivamente el primer esquema descriptivo. lo que implica una descripción de los datos mediante el uso del lenguaje natural. aunque la más usada es la de entrevistas a los usuarios. Se pretende en esta etapa elaborar un esquema descriptivo del mundo real. el de que la base de datos ha de ser un servidor operacional y eficiente de los datos. es decir. Sin embargo. conjunto de información que puede ser accedida por un usuario) y lógico (estructura de tablas y restricciones) de la arquitectura ANSI/X3/SPARC. y que constituye la primera fase de diseño. El diseño conceptual es una etapa previa al diseño lógico. la normalización no cubre toda esta fase. Los problemas que presenta esta primera especificación. Visión general sobre el diseño de bases de datos. Esta reestructuración toma como entrada el esquema relacional estructurado obtenido anteriormente. El modelo relacional es el único modelo que ha permitido abordar la fase de diseño lógico aplicando una teoría formal: el proceso de normalización. así como el análisis de los requisitos de determinadas vistas o aplicaciones críticas. • Diseño lógico El objetivo del diseño lógico es transformar el esquema conceptual obtenido en la fase anterior. en la que una vez estructurado el esquema origen. La Figura 3 muestra la correspondencia existente entre las fases de diseño y los niveles de la arquitectura ANSI/X3/SPARC. se detallan las dos etapas en las que se divide la fase de diseño lógico. Ahora bien. La Figura 4. se irán refinando hasta obtener el esquema conceptual. si se tiene en cuenta el segundo de los objetivos mencionados anteriormente. incluye 17 . Conceptualización: En esta etapa se intenta responder a la pregunta: ¿cómo representar?. mostrándose insuficiente para alcanzar todos los objetivos de la misma. consistente en la estructuración de las relaciones atendiendo a consideraciones de tipo lógico.© Grupo EIDOS 2. que deberá ser expresado sin tener en consideración cuestiones de implementación. es decir. el diseño lógico se corresponde con los niveles externo (donde se definen las vistas de usuario. El diseño físico se corresponde con el nivel físico de dicha arquitectura. En la Figura 4. La primera. para conseguir pasar del mundo real al esquema descriptivo y de éste al esquema conceptual. en el que priman las consideraciones de eficiencia. se hace necesaria una reestructuración de relaciones. adaptándolo al modelo de datos en el que se apoya el SGBD que se va a utilizar. debe ser independiente del SGBD a usar. resume la fase de diseño lógico. se obtiene un esquema relacional. A su vez. mediante distintas técnicas. con independencia de usuario o aplicaciones en particular y fuera de consideraciones sobre eficiencia del ordenador. En la práctica a veces es preciso proceder a una reestructuración de las relaciones. obteniendo de esta manera un esquema relacional resultante. analizando diferentes factores como las distintas dependencias o la posibilidad de existencia de valores nulos. Diseño conceptual El objetivo del diseño conceptual. es obtener una buena representación de los recursos de información de la empresa. también denominado modelo conceptual. Consta de dos fases: • Análisis de requisitos: Es en esta etapa donde se debe responder a la pregunta: ¿qué representar?.

Las herramientas para llevar a cabo este objetivo son dos: 18 . valores inaplicables. por razones lógicas. La razón de esta etapa de reestructuración se encuentra en la falta de flexibilidad de la estructura interna de los actuales SGBD. un esquema normalizado. en el cual se han eliminado los valores nulos (inaplicables) mediante un particionamiento horizontal basado en la selección. Estructuración y reestructuración de relaciones El objetivo de la estructuración de relaciones es obtener un esquema relacional estructurado. seguido de la proyección. mientras que en la segunda se reestructuran las relaciones teniendo en cuenta consideraciones de tipo físico que pueden llevar a la desnormalización. vertical o mixto. etc. los cuales no ofrecen los adecuados instrumentos de diseño físico.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS la normalización. tomando como entrada un esquema relacional origen con todas sus dependencias. obligando a trasladar a la fase de diseño lógico consideraciones de eficiencia que deberían ser ajenas a dicha fase. así como el particionamiento horizontal de las mismas cuando sea necesario. o al particionamiento horizontal. En esta etapa de estructuración se conseguirá. Figura 4.

• • El proceso de normalización El particionamiento horizontal de relaciones El proceso de normalización consiste en sustituir una relación por un conjunto de esquemas equivalentes. en varias relaciones en las que los valores nulos inaplicables no tienen cabida. Figura 6. ya que se ha logrado el primero de los objetivos de las bases de datos (ser una representación fidedigna del mundo real). El resultado de este particionamiento horizontal será la división de una relación en la que existen o pueden existir valores nulos. se ha propugnado por razones lógicas. esto no quiere decir que las relaciones que se vayan a almacenar en la base de datos sean las resultantes de estos procesos. Particionamiento horizontal de relaciones El objetivo de la reestructuración es el de mejorar la eficiencia de la base de datos. mediante un proceso de normalización. seguido de proyecciones sobre las relaciones resultantes. pero que no presentan cierto tipo de anomalías a la hora de realizar operaciones sobre ella. permite eliminar valores nulos inaplicables que pueden aparecer en las relaciones mediante un proceso de selección. Sin embargo. que representan la misma información que la relación origen. así como eliminar los valores nulos mediante un proceso de particionamiento horizontal. en la que una relación origen ha sido sustituida por otras dos. Visión general sobre el diseño de bases de datos. Figura 5. como se muestra en la Figura 5. normalizar el esquema.© Grupo EIDOS 2. En la primera etapa de estructuración de relaciones. pero puede que no el segundo: el de que la base de 19 . Normalización de relaciones El particionamiento horizontal de relaciones.

o mixta (incluye ambas). particionamiento vertical y particionamiento mixto. La Figura 7. etc. considerando esta idea de mejora de la eficiencia. los atributos de una relación R son distribuidos en grupos no solapados y la relación R se proyecta en relaciones fragmentarias de acuerdo a estos grupos de atributos. Figura 7. particionamiento horizontal. muestra un ejemplo en el que dos tablas previamente normalizadas. entonces el coste de proceso de las transacciones podría ser minimizado. acercándose al lugar de su tratamiento. A cada una de estas formas de particionamiento se la denomina. por lo que se hace necesaria esta segunda etapa en el diseño lógico. 20 . El objetivo de este proceso es dada una relación. ya que cada subconjunto puede ubicarse en distintos nodos de la red. El particionamiento horizontal de relaciones consiste en la división de las tuplas de una relación en subconjuntos. Para lograr este objetivo existen diversos métodos o formas de organizar los datos. y en la división de datos entre diferentes niveles de jerarquías de memoria. dividirla en otras relaciones de forma horizontal. Si los fragmentos se ajustan bien a los requisitos del conjunto de transacciones facilitado. Esto es muy útil cuando existen consultas que acceden sólo a determinada parte de la información dependiendo del valor de algún atributo. el objetivo del particionamiento vertical es crear fragmentos verticales de una relación de manera que minimice el coste de acceso a los elementos de datos durante el procesamiento de la transacción. El particionamiento vertical también puede usarse en la partición de tablas individuales en bases de datos centralizadas. En el caso de bases de datos distribuidas. Desnormalización de relaciones El particionamiento de relaciones es otra forma de conseguir una mayor eficiencia en la base de datos. o vertical. Por ello. mediante un proceso de desnormalización. que son: • • El proceso de desnormalización El particionamiento de relaciones El proceso de desnormalización es justamente el proceso inverso al de normalización. dan origen a una tabla más grande (que es justamente la tabla que se tenía antes de realizar la normalización). En el particionamiento vertical. Estos fragmentos se colocan en diferentes localizaciones de la base de datos distribuida. respectivamente. o en bases de datos distribuidas.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS datos ha de ser un servidor operacional y eficiente de los datos. el coste de proceso de transacciones se minimiza incrementando el proceso local de las transacciones (en un "nodo") así como reduciendo el número de accesos a objetos de datos que no son locales.

lo que explica la obligación de la etapa de reestructuración en el diseño lógico. es conseguir una instrumentación lo más eficiente posible del esquema lógico. Como su propio nombre indica. Consiste en aplicar un particionamiento vertical a uno o más de los fragmentos obtenidos mediante un particionamiento horizontal. del SO y en general. aspectos de carácter físico. 21 . características del SGBD. Con ello se persigue: • • • • • disminuir los tiempos de respuesta minimizar espacio de almacenamiento evitar las reorganizaciones proporcionar la máxima seguridad optimizar el consumo de recursos El principal problema que se plantea en la fase de diseño físico es el debido a la poca flexibilidad de los actuales SGBD. cualquier factor cercano a la "maquina". Por ello el diseño físico se genera para un SGBD y un entorno físico determinado. que es una descripción de la implementación de la base de datos en memoria secundaria. requisitos de procesos. Visión general sobre el diseño de bases de datos. que es la última fase del proceso de diseño. describe las estructuras de almacenamiento y los métodos de acceso para acceder a los datos de una manera eficiente.© Grupo EIDOS 2. Esto obliga a iterar desde la fase de diseño físico a la de diseño lógico. los cuales obligan a trasladar a la fase de diseño lógico. y viceversa. Diseño físico El objetivo del diseño físico. que deberían ser ajenos a dicha fase. o viceversa. Como resultado del diseño físico se genera un esquema físico. Aquí se tienen en cuenta aspectos del hardware. el particionamiento mixto engloba a ambos tipos de particionamiento (horizontal y vertical). hasta obtener conseguir los objetivos anteriormente expuestos.

.

Otro error que se suele cometer en esta etapa de diseño es el de considerar aspectos tales como la eficiencia del equipo hardware en el que se vaya a montar la base de datos. que represente fielmente las características del mundo real. o no representa fielmente la información del mundo real. Puesto que no se corresponde con ningún nivel de la arquitectura ANSI/X3/SPARC. Como ya se ha dicho. el diseño conceptual. viéndonos obligados a reajustarlo constantemente debido a las deficiencias arrastradas desde esta etapa de diseño. si éste no es correcto.Diseño conceptual Introducción Como ya se ha visto en el tema anterior. ya que el diseño lógico parte del esquema conceptual y. se pueden establecer las siguientes características que debe cumplir un buen esquema conceptual: Debe representar fielmente la información del mundo real • • Es independiente del SGBD Es independiente del Hardware . tiende a ser no tenido en cuenta a la hora de proceder al diseño de una base de datos. con independencia de usuario o aplicaciones en particular y fuera de consideraciones sobre eficiencia del ordenador. consiste en obtener una buena representación de los recursos de información de la empresa. sino que es un paso previo. o SGBD's concretos. el esquema de la base de datos no será estable. De ahí la importancia de realizar un buen esquema conceptual. el esquema conceptual debe representar la información fuera de consideraciones sobre hardware y sobre el SGBD sobre el que se implementará. Por lo tanto. que constituye la primera etapa en el diseño de una base de datos. Esto no es aconsejable.

sino distintos modelos según los autores. lo cual explica que no exista uno sólo. El objetivo es elaborar un esquema descriptivo de la realidad.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Conviene no olvidar. etc. Al utilizar una representación de este tipo. la que se utilizará aquí no es. que se apoye en un modelo de datos que cumpla determinadas propiedades (según Piattini y De Miguel): coherencia. Etapa de conceptualización: En esta etapa se debe responder a la pregunta "¿Cómo representar?". por supuesto. Aislar la representación de la información de los requisitos de máquina y exigencias de cada usuario en particular 3. En ella se transforma el esquema obtenido en la primera. fidelidad. el modelo E/R permite distinguir fácilmente y a simple vista. A continuación se describirá el proceso de creación de un esquema conceptual. permite una mejor y más fácil comprensión de la información por parte del usuario. hasta llegar al esquema conceptual. Posteriormente se fueron proponiendo nuevas aportaciones al modelo. y le permite especificar los requisitos sin la intervención de formalismos. se ira refinando sucesivamente.). Este primer esquema percibido bruto (como lo llaman Benci y Rolland). 2. El modelo que se estudiará es el Modelo Entidad / relación (en adelante referido como ME/R o modelo E/R). En ellos define dicho modelo como una vista unificada de los datos. las relaciones existentes entre las distintas entidades. 2. con independencia de consideraciones de tipo físico. siguiendo el modelo E/R. no redundancia. por lo tanto. Aunque existen muchas respuestas sobre el modo de recoger dicha información. como ya se ha comentado. etc. Etapa de análisis de requisitos: En esta etapa se debe responder a la pregunta "¿Qué representar?". que es el más utilizado hoy en día. aunque carece del formalismo que pueden infligir otros métodos. puede subdividirse a su vez en dos etapas: 1. Éste se basa en una representación gráfica de una serie de entidades relacionadas entre sí. la única forma de hacerlo. Los elementos de los que se componen son los siguientes: 24 . simplicidad. que un buen diseño del esquema conceptual. en el que se provean detalles de los datos a representar. Los objetivos que debe cumplir un esquema conceptual son los siguientes (Piattini y De Miguel): 1. Chen en dos artículos que publicó en los años 1976 y 1977. Dicho esquema se obtiene mediante el estudio u observación del mundo real (estudio de las reglas de la empresa. influirá positivamente en el resto de etapas. plenitud. El modelo entidad / relación El modelo E/R fue propuesto por Peter P. mediante refinaciones sucesivas. como representación del mundo real. Independizar la definición de la información de los SGBD en concreto. centrándose en la estructura lógica y abstracta de los datos. la más utilizada es el lenguaje natural que. Captar y almacenar el universo del discurso mediante una descripción rigurosa. Existen muchas formas de representarlo. Etapas del diseño conceptual La fase de diseño conceptual. Se deberá obtener el esquema conceptual mediante una representación normalizada. entrevista a los usuarios.

Esto implica que los valores de los atributos clave no se pueden repetir para dos ocurrencias de la misma entidad. y Un automóvil pertenece a una persona.© Grupo EIDOS 3. marca. Entidades: Una entidad es "una persona. una correspondencia entre dos entidades. Diseño conceptual 1. Figura 10 4. Figura 8 2. se representa por un rectángulo. Atributos: Un atributo es cualquier característica que describe a una entidad. modelo o color. un atributo clave se representa subrayando dicho atributo. Es decir. hace referencia. cosa. concepto o suceso. Clave: La clave de una entidad es un atributo o conjunto de atributos de dicha entidad. Figura 9 3. con el nombre de dicha entidad escrito en la parte superior. En el modelo E/R. se puede decir que un automóvil tiene las siguientes características: nº de matricula. ya que pueden existir dos automóviles distintos de la misma marca. entre todas las posibles. seremos capaces de identificar de que automóvil estamos hablando. podemos tener una relación entre ellas. la Figura 8 representa la entidad automóvil. Relación: Una relación representa. seremos capaces de conocer a que ocurrencia de entidad. modelo o color no identifican unívocamente una ocurrencia de la entidad. modelo y color. que son capaces de identificar unívocamente una ocurrencia de una entidad. En nuestro ejemplo. Los atributos marca. si conocemos el valor de dichos atributos. como su propio nombre indica. 25 . lo cual se muestra en la Figura 9. de interés para la empresa" (ANSI 1977). En el modelo E/R. justo debajo del nombre de ésta. lugar. Los atributos de una entidad se colocan dentro del rectángulo que representa dicha entidad. Si tenemos dos entidades automóvil y persona. ya que no existe una misma matrícula para dos automóviles distintos. real o abstracto. con sólo conocer el valor del atributo matrícula. Por ejemplo. Por ejemplo. Dicha relación se puede establecer en ambos sentidos: una persona posee un automóvil.

Puede ser de tres tipos: Cardinalidad 1-1: cada ocurrencia de una entidad se relaciona con una ocurrencia de otra entidad. Cada ocurrencia de una entidad puede relacionarse con varias ocurrencias de otra entidad. Cardinalidad de una relación: La cardinalidad de una relación representa el número de ocurrencias que se pueden dar de una relación. Figura 13 6. 8. Se representa como aparece en la Figura 13. 7.: una persona posee varios automóviles y un automóvil puede pertenecer a varias personas.: un automóvil debe pertenecer como mínimo a una persona. Cardinalidad mínima de una relación: representa el número mínimo de ocurrencias de una entidad con las que se puede relacionarse otra entidad. cuando no somos capaces de conocer a que ocurrencia de entidad nos estamos refiriendo. ni siquiera conociendo su clave. Se representa como indica la Figura 11. Figura 11 Cardinalidad 1-N: también llamada uno a muchos. Cardinalidad máxima de una relación: representa el número máximo de ocurrencias de una entidad con las que se puede relacionarse otra entidad.: una persona puede tener como máximo tres automóviles. Ej.: una persona posee varios automóviles. Ej.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS 5. Cada ocurrencia de una entidad puede relacionarse con varias ocurrencias de otra entidad y viceversa. Se representa como muestra la Figura 12. o es dependiente de otra.: una persona posee un automóvil. Ej. sino que debemos conocer el valor de algún otro atributo de otra 26 . Ej. Ej. Entidad débil: se dice que una entidad es débil. Figura 12 Cardinalidad N-M: también llamada muchos a muchos.

(nos fijaremos sólo en un sentido de la relación.© Grupo EIDOS 3. Cardinalidad máxima 1. el de la izquierda). Esto significa que en el modelo no interesa tener información de aquellas personas que no tengan automóvil. Figura 16 En la Figura 17. sino que además se necesita conocer el código del edificio al que se hace referencia. se tiene una relación 1-1 en la que un automóvil pertenece a una única persona (cardinalidad máxima 1). se tiene una relación 1-1 en la que una persona puede tener un automóvil como mucho (cardinalidad máxima 1). Por ejemplo. si tenemos las entidades edificio (con el atributo clave codigo_edificio) y planta (con el atributo codigo_planta). cardinalidad mínima 1. Los tipos de cardinalidades son los que aparecen en la Figura 15. por ejemplo. si se tienen las entidades alumno y asignatura. Figura 14 En general. 27 . Cardinalidad máxima 1. sin la posibilidad de que exista un automóvil que no tenga dueño (cardinalidad mínima 1). si dicha ocurrencia se debe dar obligatoriamente. Cardinalidad máxima N. Cardinalidad máxima N. o si por el contrario se puede obviar. aunque no tengan automóvil. Como se podrá comprobar. es decir. la cardinalidad de la relación un alumno cursa asignaturas. Figura 15 Veamos a continuación unos ejemplos para comprender mejor las cardinalidades máxima y mínima. Diseño conceptual entidad. las cardinalidades de una relación se ponen en la última relación a la que se hace referencia. En los anteriores casos no se han considerado las cardinalidades mínimas. o puede no tener ninguno (cardinalidad mínima 0). en una relación se suele representar conjuntamente las cardinalidades máxima y mínima. se pondrá al lado de la entidad asignatura. Esto significa que el modelo interesa tener información de todas las personas. ya que no somos capaces de identificar una planta con sólo conocer el código de la planta. para determinar la planta dentro del edificio. ésta última es una entidad débil. cardinalidad mínima 0. cardinalidad mínima 1. En el siguiente ejemplo(Figura 16). Éstas vienen a representar la opcionalidad de la ocurrencia de una entidad en una relación. cardinalidad mínima 1.

Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Figura 17 En el siguiente ejemplo (Figura 18). en la que una persona puede tener varios automóviles (cardinalidad máxima N). número de socio. la editorial. el título. aunque no tengan automóvil. Se dispone. se tiene una relación N-N. apellidos. Por cuestiones directivas. dirección y teléfono. pero puede que no tenga ninguno (cardinalidad mínima 0). Para cada libro interesa conocer el ISBN. Figura 19 Para concluir esta sección se verá un ejemplo completo que representará todos los conceptos vistos hasta ahora. Deberá quedar constancia de la fecha de préstamo de cada ejemplar. en la que un profesor puede dar clase a muchos alumnos (cardinalidad máxima N). se limita el número de ejemplares prestados a cada usuario a uno. el autor o autores. Esto significa que en el modelo no interesa tener información de aquellos profesores que no dan clase. por lo que un libro prestado a un usuario. a su vez. Esto significa que en el modelo interesa tener información de todas las personas. 28 . De la editorial se desea conocer el nombre y la ciudad. el año de publicación y la materia. de un único ejemplar de cada libro. se tiene una relación 1-N. Se desean tener almacenados todos los libros que la componen. nombre. De ellos se quiere saber su DNI. Un autor podrá haber escrito varios libros. A dicha biblioteca podrán estar suscritos varios usuarios. de la misma forma que en un libro pueden participar varios autores. Supongamos que se desea establecer un modelo conceptual para la gestión de una biblioteca. apellidos y nacionalidad. pero como mínimo debe hacerlo a uno (cardinalidad mínima 1). De cada autor se quiere conocer su nombre. Figura 18 En el siguiente ejemplo. no podrá ser prestado a otro hasta que se devuelva.

Además. son las que tienen como origen o destino a la entidad préstamo. ya que se desea conocer información de ellos. Esto quiere decir que sólo se guardará información de las entidades cuando exista. Pues bien. que es una herramienta CASE que abarca gran parte del ciclo de vida de las aplicaciones. para ir familiarizando al lector con los conceptos vistos hasta ahora. simplemente quédese con la idea general de la construcción del esquema. como puede ser un código que lo identifique dentro de la estantería. de los cuales se desea almacenar su nombre. ya que se verá en detalle en próximos temas. Así mismo se desean almacenar los clientes que han comprado en dicha tienda. Para ello se desean tener almacenados los nombres de todos los discos disponibles. La cuarta estará formada por los clientes. dirección y teléfono. Diseño conceptual Figura 20 Lo más destacable del anterior ejemplo es la entidad préstamo.© Grupo EIDOS 3. además de sus cantantes y canciones. lo cual es lógico. y que además tendrán sus propias letras. Ejemplos prácticos de diseño conceptual A continuación resolveremos unos problemas de diseño conceptual. También se pueden observar que las cardinalidades mínimas son 1. Pues ya tenemos la tercera entidad. y que podrán estar identificados internamente por un código de cliente. No se preocupe si no conoce la herramienta. ya que tendremos información de todas las entidades. Supóngase que se desea informatizar una tienda de discos. empezaremos identificando las entidades. Las únicas relaciones que tienen cardinalidad opcional. y para cada uno de ellos se desea conocer su nombre y apellidos. incluyendo el diseño de esquemas conceptuales. podemos establecer los discos que se venden. entendiendo por entidad un grupo de características que tienen entidad propia. apellidos. Figura 21 29 . aunque todavía no se haya realizado ningún préstamo. Como primera entidad. identificada cada una de ellas por un código de canción. se desea conocer todas las canciones que están disponibles en los discos. una ocurrencia de la entidad. sino el socio al cual se ha prestado. Es una entidad débil que depende de libro y de socio. Por otro lado se desea almacenar todos los artistas que intervienen en los discos de nuestra tienda. al menos. ya que para diferenciar un préstamo de otro. se necesita saber no sólo el libro. Para realizarlos se utilizará la S-Designor. por lo tanto ya tenemos identificada una segunda entidad. El problema que nos planteamos es el siguiente.

Empezamos identificando entidades. apellidos. Entre disco y canción: en un disco pueden aparecer varias canciones. Por ejemplo podemos tipificar las ciudades.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Una vez establecidas las entidades. Cuando almacenemos la ciudad de un alumno. Otra entidad podría ser el alumno. muy usado en el diseño conceptual. dirección y despacho. y que consiste en tener una entidad que tipifique los posibles estados que puede tomar un atributo. del cual se desea conocer su nombre. Entre cliente y disco: un cliente puede comprar varios discos. podemos recurrir a un procedimiento muy usual. así como una breve descripción de éstos. el esquema conceptual es que muestra la Figura 22 Figura 22 Vamos a plantearnos otro problema. para lo cual creamos una nueva entidad ciudad. De un profesor se desea conocer su nombre y apellidos. de la cual se desea conocer su descripción. Sin embargo. dirección y teléfono. y los alumnos a los cuales se les ha impartido. donde se almacenará un código y la descripción de la ciudad. 3. Por lo tanto. Supongamos que se desea tener almacenados todos los datos de los profesores de una empresa dedicada a impartir cursos. denominado tipificación de estados. pero un disco sólo puede ser comprado por un cliente 1-N. Podemos observar las siguientes relaciones: 1. 2. Entre cantante y canción: un cantante puede componer varias canciones. y cada canción puede estar en varios discos (N-M). por lo tanto establece una entidad. sólo nos queda relacionarlas. La principal ventaja de este procedimiento radica en que muchas veces supone un ahorro de espacio de almacenamiento (por ejemplo al identificar nombres de ciudades largas con un solo número) además de una estandarización de los datos almacenados (el estado sólo se almacena una vez). Ni que decir tiene que el curso describe otra entidad. y una canción puede estar compuesta por varios cantantes (N-M). 30 . sólo deberemos especificar el código de la ciudad.

el esquema conceptual es el mostrado en la Figura 24. Profesor y Curso: un profesor puede impartir varios cursos. 3. vamos a definir las relaciones entre ellas. 2. Por lo que podrá ser introducido en la entidad intermedia que surja cuando se haga el paso a tablas (véase siguiente capítulo). y a un curso pueden asistir varios alumnos (N-M).© Grupo EIDOS 3. pero un curso sólo puede ser impartido por un profesor (1-N). Figura 24 Cabe destacar que el atributo calificación se da como consecuencia de la relación entre las entidades curso y alumno. 31 . Diseño conceptual Figura 23 Una vez establecidas las entidades. 1. Alumno y Ciudad: un alumno vive en una ciudad. Por lo tanto. Alumno y Curso: un alumno puede asistir a varios cursos. y una ciudad puede tener varios alumnos (1-N).

). por lo que desea conocer en todo momento la situación de dichas empresas. Reunión: entidad encargada de describir la información de las actas de las reuniones. así como la oferta de nuevos productos. Como habrá podido observar. Puesto que dicho banco esta constituido como sociedad anónima. libretas de ahorro. Tipo_cargo: describe los posibles cargos que puede tomar una persona en el consejo de administración. Figura 25 32 . Las decisiones de inversión en estas empresas saldrán como resultado de dichas reuniones. 5. De la misma forma. este ejemplo es un poco más complejo. Cliente: se desea conocer su nombre. Sus atributos son cod_reunión. Empresa: identifica las empresas en las cuales el banco ha invertido.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Vamos a ver un último ejemplo. Producto: del cual queremos saber su descripción y estará identificado por un código interno cod_producto. fecha. 4. dicho banco tiene intereses en otras empresas. y esta compuesto por un código de tipo de cargo. que especifica si la reunión ha sido ordinaria o extraordinaria y una descripción. Supóngase un banco que desea almacenar todos sus clientes. Empezaremos definiendo entidades y las veremos representadas en la Figura 25. etc. etc. Podremos utilizar una nueva entidad que tipifique los tipos de cargo. apellidos. dirección y NIF. De ellas se desea conocer su código. Cada cliente podrá escoger entre todos estos productos el o los que más le plazcan (créditos.). y estará identificado por un código interno cod_cliente. Para ello se almacenará el nombre. para poder mejorar su política de inversiones. 2. fondos de inversión. 3. presidente. además de los productos que puede ofrecer a éstos. pero no desespere. apellidos y código de cargo de cada uno de sus componentes. y una descripción del mismo (secretario. nombre y CIF. el proceso es similar al de los demás ejemplos. y si el cargo es vigente o no. 1. desea almacenar todos los componentes de su consejo de administración (actuales y ex-miembros) así como todas las actas de las reuniones ordinarias y extraordinarias. 6. extraordinaria. Consejo: establece los componentes del consejo de administración.

4. Diseño conceptual Identifiquemos ahora las relaciones. 3. y cada miembro puede asistir a más de una reunión. 5. 1. Reunión y consejo: a cada reunión pueden asistir varios miembros del consejo de administración. Reunión y producto: de cada reunión puede salir la oferta de mas de un nuevo producto pero cada producto nuevo sólo puede salir de una reunión. y cada decisión de inversión sólo sale de una reunión. Reunión y empresa: de cada reunión pueden salir decisiones de invertir en más de una empresa. Consejo y cargo: un miembro del consejo sólo tiene un cargo.© Grupo EIDOS 3. 2. y cada cargo puede pertenecer a más de un miembro. 33 . Cliente y producto: cada cliente puede escoger varios productos. y cada producto puede ser ofrecido a varios clientes. Su representación gráfica aparece en la Figura 23.

.

etc. jerárquico. la desnormalización. lenguajes SQL).. En el diseño lógico estándar. En la fase de diseño lógico.). . SQL-SERVER. y considerando el modelo lógico específico (MLE) propio del SGBD a usar (ORACLE. ya que ambos dependen mucho del SGBD que se utilice. El diseño lógico específico está muy ligado a la fase de diseño físico. el diseño lógico de una base de datos consta de dos etapas: el diseño lógico estándar y el diseño lógico específico. se elabora el esquema lógico específico (ELE). se disponen de otras que permiten establecer un buen diseño lógico. de construye un esquema lógico estándar (ELS). Una vez obtenido el ELS. se toma el esquema conceptual resultante de la fase de diseño conceptual. se usará el TRANSACT SQL). y teniendo en cuenta los requisitos de proceso. además de las herramientas ya descritas (MLS. que se apoya en un modelo lógico estándar (MLS).). Una buena forma de describir el ELS es utilizando el lenguaje estándar del MLS (por ejemplo SQL).Diseño lógico Introducción Como ya se ha señalado. una buena forma de describirlo es utilizando el lenguaje de definición de datos (LDD) del producto especifico utilizado (en el caso de SQL-SERVER. que ya se verán mas adelante en este tema. que será el mismo modelo de datos soportado por el SGBD a utilizar (relacional. Al igual que en el caso anterior. MLE. En nuestro caso se utilizará el MLS relacional. INFORMIX. pero sin las restricciones de ningún producto comercial en concreto. como por ejemplo la normalización. etc. etc.

Para entender mejor el funcionamiento de este método. es decir. A su vez. tanto del libro como del autor. Posteriormente. apellidos y telefono. Cada relación 1-N importa las claves de la entidad con las que se relaciona: cada relación con cardinalidad 1-N importa los atributos clave que contiene la entidad con cardinalidad N. la entidad cliente generará su propia tabla. ISBN y Num_socio. como clave. y concretando las tablas que generarán: 1. Las reglas que permiten pasar del modelo E/R al esquema lógico. Esta tabla. es decir. mantiene información de qué libros han sido prestados a qué usuarios y en qué fecha. Empezaremos identificando las relaciones. El esquema de las tablas resultantes es el que se muestra en la Figura 26 Figura 26 Veamos ahora el paso a tabla de otro ejemplo visto en el tema anterior. es obtener el esquema lógico estándar. La entidad libro está relacionada con la entidad editorial con cardinalidad 1-N. la cardinalidad es N-M. pero en este caso. Cada relación dependiente. cada entidad genera una tabla.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Paso del esquema conceptual al esquema lógico estándar Lo primero que hay que realizar en la fase de diseño lógico. incluyendo las claves. Cliente-Disco: puesto que es una relación 1-N. cod_cliente. con sus propios atributos. Cada relación N-M genera una tabla: las relaciones entre entidades con cardinalidad N-M generan una tabla. con sus mismos atributos. importa la clave de la otra entidad. lo que quiere decir que se generará una tabla. con los atributos de la entidad Préstamo además de las claves de las entidades de las que es dependiente. cod_cliente. 36 . Esta última relación obtenida. A su vez. por lo tanto importa la clave de la entidad con cardinalidad 1. veamos el paso a tablas del ejemplo visto en el tema anterior acerca de la gestión de una biblioteca. a partir del esquema conceptual obtenido en la primera fase. si se desea extraer más información. que entrarán como claves en dicha tabla. e importará el atributo clave de la entidad con cardinalidad 1. que es dependiente tanto de la entidad Libro como de la entidad Usuario. con los atributos clave de ambas entidades. es decir. esta relacionada con la entidad con la entidad autor. lo que implica que se generará una tabla intermedia. la entidad disco generará una tabla con sus atributos. son las que a continuación se explican: • • • • Cada entidad se transforma en una relación: esto es. Por último se dispone de la entidad Préstamo. en la que se almacenarán las claves de ambas entidades. se deberá acceder a sendas tablas. nombre. a la que denominaremos Libro_autor mantiene la información de los códigos de libros junto con los códigos de autores. cuyo esquema conceptual es el que muestra la Figura 27.

se considera aquí debido a la falta de flexibilidad de los SGBD. obligando a trasladar a esta etapa aspectos 37 • . queda como aparece en la Figura 28. con los atributos cod_cantante y cod_disco. Diseño lógico 2. y el proceso de normalización. a si que. que debería ser ajena al diseño lógico. Figura 27 Con todo esto. Canción-Cantante: en este caso se tiene una relación N-M. es decir. se generará una tabla intermedia. siguiendo el mismo razonamiento anterior. el esquema lógico resultante del esquema conceptual anterior. al ser una relación N-M. la fase de diseño lógico de una base de datos consiste en dos etapas: • Etapa de estructuración: donde el objetivo primordial es encontrar un esquema que sea una representación fidedigna del mundo real.© Grupo EIDOS 4. la tabla canción generada importará el cod_disco de la entidad disco. Etapa de reestructuración: donde se tienen en cuenta aspectos más ligados con el nivel físico. es decir. Disco_Cantante: siguiendo el mismo razonamiento. Disco-Canción: es una relación 1-N. Figura 28 Etapas en el diseño lógico Como ya se ha comentado. se generará una tabla intermedia. Esta etapa. con los atributos claves de las entidades que relaciona. 4. cod_canción y cod_cantante. para evitar valores nulos. y que consiste el modificar el esquema obtenido en la fase anterior para adaptarlo a las consideraciones de eficiencia. La forma de lograrlo es mediante el particionamiento horizontal. 3.

Cod_publicación Título 123BB3-3 113ZD3-0 2322-DD El Quijote El impacto de las TI Rimas y Leyendas Autor Miguel de Cervantes Francisco Hierves G. Aquí la diferenciación se establece entre aquellas filas que tienen editorial. como es obvio. y parte a otra. bien sea horizontal. para dar paso posteriormente al proceso de normalización. Becquer Editorial Ibérica Alcalá 38 . A. separar las filas que conforman una relación. editorial. título. para llevarlas a otra. con los siguientes campos: cod_publicación. el particionamiento horizontal consiste en dividir longitudinalmente las filas que forman una tabla. la información que tenemos en la tabla es la mostrada en la Tabla 1. y aquellas que no tienen editorial. mientras que la Tabla 3 contiene los artículos. dejando para el final el particionamiento vertical. En un momento dado. no tiene editorial. Para entenderlo mejor. La Tabla 2 posee la tabla de libros. autor.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS mas relacionados con el nivel físico. La forma de lograrlo es mediante la desnormalización. vertical o mixto. y un artículo (El impacto de las TI) que. Por lo tanto. mixto y la desnormalización. A. usado tanto en la etapa de estructuración como en la de reestructuración. Particionamiento horizontal de relaciones Como su propio nombre indica. o artículos. podría ser conveniente "partir" dicha tabla horizontalmente en otras dos. supóngase el siguiente ejemplo en el que se tiene la tabla publicación. es decir. Becquer Tabla 1 Editorial Ibérica Alcalá Tenemos información sobre dos libros. es decir llevar parte de la información a una tabla. esto es. Comenzaremos por estudiar el particionamiento horizontal de relaciones. En este caso. y el particionamiento. Cod_publicación 123BB3-3 2322-DD Título El Quijote Rimas y Leyendas Tabla 2 Autor Miguel de Cervantes G. con su autor y su editorial correspondiente. se crean dos tablas: una para albergar los libros y otra para ubicar los artículos. libros.

• En este caso. Supongamos. nos podemos plantear varias cuestiones: 1. por ejemplo.© Grupo EIDOS 4. inexistente o no válida (en nuestro caso el valor del atributo editorial en el artículo). el coste del acceso remoto aumenta (si toda la información está en Madrid. Si se sitúa toda la información en ambos nodos. y las calificaciones obtenidas en cada una de las asignaturas. mientras que la tabla profesor 39 . Esto que acabamos de realizar. correspondiente a una base de datos para gestionar los alumnos de una empresa de educación a distancia. los aplicables pueden dejar de serlo en algún momento. alumno y profesor. y suponiendo que se dispone de dos nodos. y ubicar únicamente la información de los clientes que viven en Madrid en dicho nodo. una consulta de un cliente que vive en Barcelona se debería realizar al nodo de Madrid. Figura 29 Sobre el esquema de la Figura 29. Mientras los no aplicables no cambian. lo lógico sería pensar en situar la información de aquellos clientes que residen en Barcelona en dicho nodo. en el nodo de Barcelona. Sin embargo. con determinada información en cada uno) con información acerca de clientes. sino que también puede usarse en la fase de reestructuración para conseguir una mayor eficiencia. Los motivos son los siguientes: • Si se sitúa toda la información en un único nodo. el particionamiento horizontal no sólo se utiliza aquí. pues. Por ejemplo. es el primer paso que se debe seguir en el proceso de estructuración de relaciones. La tabla alumno guarda sus datos personales. para situar aquellas filas que correspondan a clientes de Madrid. el coste de almacenamiento aumenta al tener toda la información duplicada. Los valores nulos pueden ser aplicables o no aplicables. es decir. Diseño lógico Cod_publicación 113ZD3-0 Título El impacto de las TI Tabla 3 Autor Fco. en el nodo de Madrid. si se dispone de una base distribuida (para entendernos. con el coste que ello supone). Un valor nulo es aquel que representa información desconocida. una base de datos con distintos nodos. uno en Madrid y otro en Barcelona. situados en distintas localizaciones. que tenemos el siguiente esquema lógico. Se dispone de dos tablas. lo que se deberá realizar en un particionamiento horizontal. Hierves Con esto. permanecen nulos. y aquellas filas que correspondan a clientes de Barcelona. lo que hemos conseguido es eliminar la existencia de valores nulos no aplicables.

Opción 1 Opción 2 Cada provincia tendrá la parte de información que le interesa en su propio Si se precisa acceder a otras provincias nodo. aumentar la eficiencia de la base de datos. para adecuarla a las necesidades de cada una de las provincias donde se encuentra ubicada la base de datos. la opción que más nos interesa es ubicar cada parte de información relevante a cada una de éstas. al evitar el acceso por red a otras provincias. es decir. podemos optar por tres opciones: Opción 1: colocar la base de datos en un sólo nodo (centralizado). 3. En la Tabla 4 se analizan las ventajas e inconvenientes de cada una de la anteriores opciones. Los alumnos pueden optar por dos ramas. se aumenta el tiempo de acceso (tráfico de red) consultas / actualizaciones. la respuesta es bastante simple: mediante el particionamiento horizontal. disminuyendo el tiempo de número de provincias. pues bien. y teniendo la premisa expuesta de que cada provincia trabajará de manera aislada. La base de datos se encuentra distribuida. Opción 2: colocar la parte de información relevante a cada nodo en cada uno de ellos. además de sus datos personales. Para ello se deben seguir los siguientes pasos: Paso 1: Realizar una consulta para separar las filas correspondientes a cada provincia. las aulas donde dicho profesor imparte cada una de las clases. Tabla 4 Opción 3 Analizando la anterior tabla. y en la provincia donde se encuentre la base de datos se disminuirá el tiempo de acceso inconvenientes El resto de las provincias deberá acceder a la provincia donde se encuentre la base de datos. y para cada una de ellas se imparten dos asignaturas. y matemáticas y ciencias en la rama de ciencias. arte y latín en letras. La pregunta que surge ahora es ¿cómo se puede realizar?. Ventajas Se disminuye el espacio de almacenamiento (una sola copia de la información). información de todas las provincias en su de forma directamente proporcional al propio nodo. 40 . Cada provincia tendrá toda la Se aumenta el espacio de almacenamiento. en cada una de las tablas. Opción 3: colocar una copia de toda la base de datos en cada nodo. con el tráfico de red y aumento de tiempo de acceso que esto supone. en su nodo local. Nos planteamos. 2. Puesto que en cada nodo sólo precisa información relevante a éste. donde se almacena la información relevante a ésta. acceso.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS almacena. al que accederán los demás. entonces. se dispone de un nodo en cada una de las provincias. lo que aumenta la eficiencia en las distintas. ciencias o letras.

Veamos un ejemplo para comprenderlo mejor. mediante un particionamiento horizontal. respectivamente. que es el de obtener de ambas tablas solamente aquellas filas que corresponden a la provincia de Madrid. ya que se verán en detalle más adelante. nuevamente. en la tabla alumno_letras. cod_material. denominadas alumno_ciencias y alumno_letras. La forma de proceder es. se encuentran atributos que hacen referencia a las calificaciones obtenidas en ambas ramas. cod_cliente. ciudad_proveedor. podremos decidir separar las filas de dicha tabla entre otras dos. dos valores nulos inaplicables en cada fila de la tabla. al menos. De esta manera. Para ello se realizará una "criba" en ambas tablas donde el campo provincia sea Madrid. Las tablas quedarían entonces como muestra la Figura 30. pero manteniendo intacta la información correspondiente a las filas. Diseño lógico Paso 2: Ubicar la información obtenida en cada uno de los nodos correspondientes a dichas provincias. nombre_proveedor. cada una de ellas almacenando los atributos correspondientes a cada una de estas ramas. 41 . al contrario que en el caso del particionamiento horizontal. aquellos que han optado por la rama de ciencias. y en la tabla alumno_ciencias. en dividir las tablas de forma transversal. Supóngase que tenemos la tabla reparto con la información de todos los repartos realizados por los proveedores a los clientes. Llegados a este punto. Como ejemplo. Figura 30 Particionamiento vertical de relaciones El particionamiento vertical de relaciones consiste. La información que tenemos de dicha tabla (Tabla 5) es: cod_proveedor. Otra de las cuestiones que hemos planteado es la referente a las ramas por las que puede optar un alumno: letras o ciencias. ya que un alumno puede optar por una de las dos ramas. con el objetivo de eliminar estos valores nulos no aplicables. nombre_cliente. lo que supone que siempre se darán. supóngase que se desean ubicar las filas de las tablas alumno y profesor en el nodo provincial de Madrid. Quédese simplemente con la idea de su funcionamiento. crear nuevas tablas con la información correspondiente a un subconjunto de los atributos de las mismas. SELECT * FROM alumno WHERE provincia = "Madrid" SELECT * FROM profesor WHERE provincia = "Madrid" Código fuente 1 No se preocupe demasiado si no entiende las anteriores sentencias. ciudad_cliente y cantidad. pero no por ambas. estarían solamente las filas o tuplas correspondientes a alumnos que han escogido la rama de letras. De esta manera es preciso proceder para el resto de las provincias. La sentencia SQL que realiza se ve en el Código fuente 1. Podemos observar como en la tabla alumno.© Grupo EIDOS 4. es decir.

podría interesarnos tener varias tablas: una que contenga la información del proveedor. nombre_proveedor ciudad_proveedor Pepe Luis Antonio Sevilla Madrid Barcelona Tabla 6 nombre_cliente Juan Paco Ángel ciudad_cliente Sevilla Cuenca Manresa Tabla 7 cod_proveedor 123 128 837 cod_cliente 113 114 998 Tabla 8 cod_material 112 118 128 cantidad 10 29 12 42 . con los atributos nombre_proveedor y ciudad proveedor. cod_cliente. otra con la información del cliente con los atributos nombre_cliente y ciudad_cliente y otra con la información de los repartos con los atributos cod_proveedor. Para ello realizamos un particionamiento vertical. sobre estos atributos.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS cod_ cod_ proveedor cliente 123 128 837 113 114 998 cod_ material 112 118 128 nombre_ proveedor Pepe Luis Antonio nombre_ cliente Juan Paco Ángel Tabla 5 ciudad_ proveedor Sevilla Madrid Barcelona ciudad_ cliente Sevilla Cuenca Manresa cantidad 10 29 12 Dada la Tabla 5. cod_material y cantidad.

a los que deberemos acceder en cada consulta. ya que deberemos obtener toda la fila correspondiente a ese empleado. la concurrencia aumenta. un aumento del número de operaciones de Entrada / salida (puede que la fila entera no quepa en el buffer de memoria. el acceso (o bloqueo de tupla) se realiza al nivel de fila o tupla. ya que escapan del objetivo del presente curso. sin únicamente deseamos obtener el sueldo de un empleado. la información a la que accedemos tendrá más probabilidad de ser utilizada. Figura 30 Si nos damos cuenta. no puede ser accedida por otro usuario. si un usuario accede a una fila de una tabla. Este proceso se realiza en la reestructuración. para extraer un solo atributo con todos los inconvenientes que esto supone. Aumento de la velocidad de consulta / actualización: al ser las tablas más pequeñas. un mayor consumo de memoria (por el mismo motivo). Disminución de tiempos de consulta de información irrelevante: si se quiere consultar un solo atributo de una tabla. es decir. en la que se almacenan los datos personales de los empleados de una empresa.© Grupo EIDOS 4. Entre ellas destacan: • Aumento de la concurrencia: cada vez que un usuario accede a una fila de la tabla. • • Por contra. aunque no nos interese su valor. ésta se bloquea. etc. supóngase que se dispone un esquema lógico con una sola tabla. otro podrá acceder a la misma fila en otra tabla. por ejemplo el de Navathe y Ra. una consulta o actualización podrá realizarse en un menor tiempo. En cambio. Nos plantemos entonces un particionamiento vertical. pero más tablas con menos atributos. se puede separar esta tabla en 43 . se accede a toda la fila de la tabla. es decir. Por ejemplo. al reducir el tamaño de las filas. Para ello existen varios algoritmos. Es por ello por lo que hay que realizar un estudio pormenorizado de la probabilidad de consultas que se va a realizar. la principal desventaja que tiene este método es el aumento del tiempo de consulta / actualización si se desea acceder a dos o más tablas. un aumento del tiempo de proceso (debemos procesar toda la fila para extraer un solo atributo). como por ejemplo una disminución de la concurrencia (otro usuario no podrá acceder simultáneamente a esa fila. se deberá acceder a toda la fila. normalmente. Al dividir un tabla en más. por ejemplo. Puesto que la única transacción (consulta) que se va a realizar (de momento) es la consulta del sueldo de un empleado. ya que se necesitarán menos accesos a disco para completar la acción. Puede que esto no nos sea útil. en los que no entraremos. ni siquiera para consultar el valor de otro atributo). Esto es debido a que. existen muchos atributos. y debamos realizar más accesos a la base de datos). es decir. ya que las ventajas que ofrece están relacionadas con la eficiencia. con lo que ello supone. Diseño lógico El resultado es que tenemos el mismo número de filas en todas las tablas.

Utilizar un atributo clave. ya que ahora se necesitaría realizar una operación de join o unión entre ambas tablas. por ejemplo para ubicar las distintas filas de una tabla en distintos nodos de una base distribuida (como el ejemplo visto anteriormente). pero no sería demasiado eficiente). La solución.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS otras dos: una con el atributo sueldo. similar para filas iguales en ambas tablas. O bien se aplica un particionamiento vertical a una tabla previamente particionada horizontalmente. utilizando el DNI. de hecho si valdría. Para identificar unívocamente cada una de estas filas. existen dos opciones: • Realizar primero un particionamiento horizontal. Figura 31 Sin embargo. quedando el esquema lógico particionado verticalmente de la como indica la Figura 31. para obtener ambos valores. Figura 32 Particionamiento mixto El particionamiento mixto consiste en un híbrido entre ambos tipos de particionamiento. ¿que pasaría si ahora se necesita saber no sólo el sueldo. De esta manera solventamos los anteriores inconvenientes que se presentaban. y otra con el resto. en este caso. sino también la categoría de un empleado?. y 44 . o 2. igual para cada fila en ambas tablas. y asociarlas a las filas de la tabla homóloga. el esquema obtenido no nos valdría (bueno. En esta caso optamos por la segunda opción.Utilizar un identificador de fila. como campo unión entre ambas tablas. pasaría por añadir el campo categoría a la tabla anteriormente extraída. se pueden usar dos métodos: 1. Por lo tanto. o bien se aplica un particionamiento horizontal a una tabla particionada verticalmente. Destacar que la operación de join es bastante costosa en tiempo de ejecución. Pues bien.

para conseguir disminuir los tiempos de acceso y posteriormente realizar un particionamiento horizontal sobre dichas tablas. El particionamiento mixto se usa en la etapa de reestructuración. el de que ha de representar fielmente la realidad. y se corresponde con la etapa de estructuración. Diseño lógico posteriormente realizar un particionamiento vertical sobre las tablas obtenidas. ya que no se conoce el valor de algún atributo no principal (que no es clave). correspondiente a los repartos realizados por distintos proveedores. para conseguir un mayor ajuste de los tiempos de acceso a datos (evitar acceder a datos irrelevantes). • Realizar primero un particionamiento vertical. después de la eliminación de valores nulos no aplicables (particionamiento horizontal). Por ejemplo. se ha particionado verticalmente en otras dos R3 y R4. al no poder insertar filas en una relación. por un conjunto de esquemas equivalentes que representen la misma información. Por lo tanto es el segundo paso a realizar dentro de la fase de diseño lógico. e indica los distintos tipos de particionamiento por los que va atravesando una determinada relación. La normalización se puede definir como el proceso de sustituir una relación o tabla. Cod_proveedor Cod_material 1 1 A234 B298 Ciudad Madrid Madrid Categoría 2 2 Cantidad 122 100 45 . y a su vez. para que cumpla el primero de los objetivos de las bases de datos. La normalización se podría considerar prácticamente como el grueso de la fase de diseño lógico. Figura 33 Teoría de la normalización El proceso de normalización consiste en la aplicación de un conjunto de reglas. ésta última. ya que es el encargado de modificar el esquema conceptual obtenido en la fase anterior. pero que no presenten cierto tipo de anomalías a la hora de realizar operaciones sobre ella. ya que se tiene en cuenta aspectos relacionados con el nivel físico (eficiencia). Las anomalías que puede presentar una relación son de tres tipos: • Anomalías de inserción: son producidas por la pérdida de información. La Figura 33 nos muestra como la relación original R se ha particionado de forma horizontal en otras dos R2 y R1. La forma de representar el particionamiento mixto se denomina árbol de particionamiento. con el objeto de verificar que el esquema relacional obtenido en esta fase cumple un cierto conjunto de reglas.© Grupo EIDOS 4. supóngase que se dispone de la siguiente relación.

no se puede reflejar en la relación. Consiste en conseguir. perderemos toda la información relacionada con él. lo que se busca con el proceso de normalización es eliminar estos tres tipos de anomalías. su ciudad y su categoría. al menos. la forma normal de Boyce-Codd (FNBC). no bastará con hacerlo en un sitio. la segunda forma normal (2FN) y la tercera (3FN). y modificar el valor de atributo ciudad en todas ellas. la base de datos quedará inconsistente. definidas por Fagin. en 3FN. Son debidas a un diseño redundante. Por ejemplo. Dichas formas normales son la primera forma normal (1FN). es decir. supóngase el caso anterior. Por estos motivos. distintas formas normales. como muestra la Figura 34. Si se desea borrar el reparto realizado por el proveedor 3. • Por lo tanto. una que este en 3FN estará en 1FN y 2FN.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS 2 2 3 G344 G392 F893 Sevilla Sevilla 3 3 200 310 400 Valencia 1 Tabla 9 Si en este momento se desea añadir un nuevo proveedor. se pueden establecer dos conclusiones: el diseño es redundante y el esquema no está normalizado. es decir. Figura 34 Una esquema relacional estará normalizado cuando esté. definida por Boyce y Codd. es decir. ya que dicho proveedor todavía no ha realizado ningún reparto. definidas por Codd. Anomalías de modificación o actualización: vienen impuestas por la necesidad de propagar actualizaciones. una relación que esté en 2FN estará en 1FN. Se dice que un esquema de relación esta en una determinada forma normal si satisface un determinado conjunto de restricciones. al eliminar una fila de una relación. y la cuarta y quinta forma normal (4FN y 5FN). se debe modificar el mismo atributo en más de un sitio. ya que si nos olvidamos de actualizar dicho valor en una fila. mediante varios pasos. sino que se deberán recorrer todas las filas correspondientes a todos los repartos de dicho proveedor. y eso sin contar el tiempo que se pierde en realizar dicha actualización. • Anomalías de borrado: vienen determinadas por la perdida de información que no se desea. Evidentemente esto es muy peligroso. existirán dos valores distintos de ciudad para un mismo proveedor. Si se desea modificar la ciudad de un proveedor. La principal característica que cumple cada una de estas formas normales es que la de nivel superior incluye a la de nivel inferior. al existir únicamente una fila con dicho proveedor. es decir. 46 . Sigamos con el ejemplo anterior.

es decir. Cod_socio ------------> ISBN ----/------> Cod_socio -----/---------> Fecha_préstamo Fecha_préstamo Fecha_préstamo Tabla 11 (1) (2) (3) ya que para un libro y un socio sólo existe una fecha de préstamo (1). y sólo si. ya que para un mismo salario pueden existir varios nombres de empleados. en la que se tiene: X --------> Y Y --------> Z Y ----/---> X 47 . se puede concluir que Fecha_préstamo tiene dependencia funcional completa de ISBN y socio. mientras que el mismo libro se puede prestar varios días (2) y un mismo socio puede tomar prestado uno o varios libros más de un día (3). La dependencia funcional plena o completa es un caso particular de dependencia funcional. etc. cada valor de X tiene asociado en todo momento un único valor de Y. Z. De la misma forma. ya que por cada DNI tenemos un nombre. compuesta por los atributos DNI. se puede concluir que entre Salario y Nombre no existe dependencia funcional. salario. se tiene: ISBN. nombre. si se tiene la relación Empleado. si se tiene la relación Libro con los atributos ISBN. Se dice que Y depende funcionalmente de X.© Grupo EIDOS 4. Otro caso particular de dependencia funcional es el de dependencia funcional transitiva. veamos el concepto de dependencia funcional. Sea X un descriptor compuesto por X1 y X2 (X1 y X2 atributos de X). Y. o que X determina o implica a Y si. Por ejemplo. Por estos motivos. Cod_socio y Fecha_préstamo. Diseño lógico Para comprender mejor el proceso de normalización y la obtención de las formas normales. (varios empleados pueden cobrar lo mismo). Sea el esquema de relación R definido sobre el conjunto de atributos A y sean X e Y subconjuntos de A llamados descriptores. y se representa X ---> Y.. se dice que Y tiene dependencia funcional plena o completa de X si depende funcionalmente de X pero no depende de ningún subconjunto del mismo. veamos la Tabla 10. Sea la relación R compuesta por los atributos X. se puede asegurar que DNI ---> Nombre . para un mismo DNI no pueden existir más de un nombre. X -------> Y X1 --/--> Y X2 --/--> Y (Y depende funcionalmente de X) (Y no depende funcionalmente de X1) (Y no depende funcionalmente de X2) Tabla 10 Por ejemplo.

que Z tiene una dependencia transitiva respecto de X a través de Y. La siguiente relación. por ejemplo. Por ejemplo. O lo que es lo mismo. es crear una fila por cada valor del atributo repetido. ya que la primera fila tiene dos valores para el atributo asignatura. y cada dirección sólo tiene un código postal (2). y se tiene la dependencia funcional que sigue: 48 . no está en 1FN. Veamos a continuación las distintas formas normales. y se representa X -------> Z. de la forma que indica la Tabla 13. además de estar en 1FN. Cod_alumno 10 10 20 Nombre L. Dirección y Cod_postal. Por lo tanto Nombre --.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS se dice. mientras que varios empleados pueden vivir en una misma dirección (3). de los cuales los atributos clave son ISBN y Cod_socio. si se tiene la relación Libro con los atributos ISBN. Por ejemplo. con los atributos Nombre. Fernández L. Cod_socio y Editorial. Fernández Asignatura Matemáticas Lenguaje 20 P. no de una parte de la clave. Fernández P. tiene un sólo valor en cada fila. Cod_alumno 10 Nombre L. entonces. cada atributo no principal (que no forma parte de la clave) tiene dependencia funcional completa respecto de cada una de las claves. se tiene: Nombre ----------> Dirección (1) Dirección --------> Cod_postal (2) Dirección ---/----> Nombre (3) cada empleado sólo tiene una dirección (1). Primera forma normal (1FN): Una relación está en 1FN si cada atributo de dicha relación.---> Cod_postal. Alonso Tabla 13 Asignatura Matemáticas Lenguaje Ciencias Segunda forma normal (2FN): Una relación está en 2FN cuando. todos los atributos que no forman parte de ninguna clave candidata suministran información acerca de la clave completa. si se tiene la relación Empleado. Alonso Tabla 12 Ciencias La forma de transformar esta relación a otra que sea 1FN sin pérdida de información.

Tercera forma normal (3FN): Una relación esta en 3FN cuando. Diseño lógico ISBN ---------------> Editorial (1) dicha relación no esta en 2FN. Para transformarla a 3FN. ya visto anteriormente. además de estar en 2FN. se descompone dicha relación en otras dos: R1 = {ISBN. con los atributos Nombre. Editorial} Este es un esquema equivalente al anterior. ya que el atributo no principal editorial. Dirección} R2 = {Dirección. denominadas multivaluadas y de unión respectivamente. Para transformarla a otro esquema equivalente.© Grupo EIDOS 4. depende funcionalmente de una parte de la clave. no existe ningún atributo no principal que dependa transitivamente de alguna de las claves de la relación. Por ejemplo. para satisfacer este requisito. cosa que puede no interesar en la mayoría de los casos. Las formas normales que se verán ahora no son muy utilizadas. cuya clave es el atributo nombre. si tenemos la relación Empleado. pero cumpliendo la segunda forma normal. ya que ahora la dependencia (1) es completa. Por ejemplo. Dirección y Cod_postal. es decir. se descompone dicha relación en otras dos equivalentes. La cuarta y quinta forma normal dependen de un tipo especial de dependencias. representa la misma información. Cod_proveedor 1 1 Cod_material A234 B298 Ciudad Madrid Madrid Categoría 2 2 Cantidad 122 100 49 . Cod_socio} R2 = {ISBN. veremos algún ejemplo sobre cómo normalizar un esquema lógico dado. así que simplemente se mencionarán. referente a los repartos realizados por varios proveedores en una empresa. es decir. que cumplan la tercera forma normal: R1 = {Nombre. con las siguientes dependencias funcionales: Nombre ----------> Dirección Dirección --------> Cod_postal (1) (2) dicha relación no se encuentra en 3FN. que esté en 2FN. Se dice que una relación esta en forma normal de Boyce-Codd cuando se tiene que para toda dependencia funcional se tiene que el implicante (la parte derecha de la dependencia) es clave. dicho esquema se encuentra en 3FN. supongamos que tenemos la instancia que aparece en la Tabla 14 de un esquema lógico. ya que supone que el esquema este muy fuertemente normalizado. no de toda ella. al tener que el atributo no principal cod_postal depende transitivamente de la clave nombre. Cod_postal} Ahora las nuevas dependencias que tenemos son (1) en R1 y (2) en R2. por lo que se ha eliminado la transitividad. Nótese que la relación original se ha descompuesto en otras dos. Ejemplos prácticos de normalización Para comprender mejor el proceso más importante en la fase de diseño lógico de una base de datos.

como podemos comprobar en las dos primeras filas. hasta lograr que este normalizado. • • 1FN: el esquema está en 1FN. La respuesta es no. con el objeto de eliminar las anteriores anomalías. Tabla 15 cod_proveedor ciudad ciudad categoría cod_proveedor. Conociendo el código del proveedor y del material. al menos. En la Tabla 15 iremos modificando el anterior esquema. conociendo el valor del código del proveedor. En nuestro caso. debemos propagar esta modificación a dos filas. perdemos la información referente a dicho proveedor. Conociendo la ciudad. es decir. con la posibilidad de la consiguiente inconsistencia del esquema. tenemos un valor distinto del atributo categoría. Actualización: si actualizamos la ciudad del proveedor 1. tenemos un valor distinto para el atributo cantidad. 2FN: el esquema no está en 2FN.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS 2 2 3 A234 G392 F893 Sevilla Sevilla Valencia Tabla 14 3 3 1 200 310 400 Lo primero que cabe preguntarse es ¿está normalizado?. estaría formada por los atributos cod_proveedor y cod_material. estamos en disposición de asegurar la ciudad del mismo. normalmente. un atributo o conjunto de atributos que identifiquen unívocamente cada tupla de la relación. Para cada valor del atributo ciudad. Lo primero es identificar las dependencias del esquema: Para cada valor del atributo cod_proveedor. ya que la combinación de estos valores no se repiten para más de una fila en la tabla. Un esquema lógico. en las que el valor 1 para el código del proveedor implica la ciudad Madrid. El atributo ciudad implica el atributo categoría. ya que en cada fila tenemos un único valor para cada atributo. ya que se producen anomalías: • • • Inserción: no podemos almacenar un proveedor. Es decir. conocemos la categoría Para cada valor distinto del conjunto de atributos cod_proveedor y cod_material. está por defecto en 1FN. cod_material cantidad Lo siguiente es encontrar una clave para la tabla. podemos saber la cantidad abastecida. hasta que no haya realizado algún reparto. aunque está en 1FN. nos encontramos con la siguiente dependencia: 50 . ya que. o para las dos siguientes en que el valor 2 para el atributo cod_proveedor implica la ciudad Sevilla. Borrado: si borramos el reparto del proveedor 3. tenemos un único valor del atributo ciudad.

deberemos descomponer dicha relación en otras dos. pero no en 3FN. de tal forma que el atributo ciudad dependa de toda la clave. para cada valor de ciudad. Relación 1 cod_maerial cantidad Cod_proveedor Relación 2 ciudad categoría Dependencias Clave Cod_proveedor. ya que en la segunda relación la clave es ahora cod_proveedor. ahora la dependencia anterior ya es completa con respecto la clave. Otra forma de proceder es dejar en una relación aquellos atributos que forman parte de la dependencia. Atributos cod_proveedor. 51 . puede ser llevar el atributo ciudad junto con la parte de clave de la que depende (cod_proveedor) a otra relación. que depende funcionalmente de una parte de la clave (cod_proveedor). ya que en una ciudad puede haber varios proveedores. • 3FN: Hasta aquí el esquema está en 1FN y 2FN.cod_material cod_proveedor. esto es. nos quedan las relaciones que muestra la Tabla 16. Diseño lógico cod_proveedor --------> ciudad Puesto que la clave de la relación esta formada por los atributos cod_proveedor y cod_material.© Grupo EIDOS 4. cod_proveedor ciudad ciudad categoría Como cod_proveedor no depende funcionalmente de ciudad.cod_material cantidad cod_proveedor ciudad categoría Tabla 16 ciudad cod_proveedor De esta manera. Una posible forma. de manera tal que se evite la dependencia funcional transitiva entre ambos atributos. que es cod_proveedor. es decir. puede haber distintos valores de cod_proveedor: ciudad --/ cod_proveedor tenemos que categoría depende transitivamente de la clave cod_proveedor: cod_proveedor categoría Por lo tanto deberemos descomponer la relación 2 en otras dos. Por lo tanto. y llevar los demás a otra relación. no de toda ella. Por lo tanto. junto con las dependencias funcionales que le afectan. ya que el atributo categoría en la relación 2 depende transitivamente de la clave de dicha relación. tenemos que hay un atributo no principal (ciudad). Esto se puede conseguir llevándonos cada dependencia a una relación distinta. por lo que el atributo ciudad depende de toda la clave.

cod_material cod_proveedor cantidad cod_proveedor Ciudad Tabla 17 ciudad cod_material Ciudad categoría De esta manera se ha eliminado la dependencia transitiva.000 20. junto con su fecha. no perdemos la información referente al proveedor. Por lo tanto hemos conseguido obtener un esquema normalizado en 3FN. es imposible que esta dependa de otra.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Atributos Relación 1 Relación 2 Relación 3 cod_proveedor cod_material cantidad Cod_proveedor ciudad ciudad categoría Dependencias Clave cod_proveedor. ya que ésta se almacena en la relación 2 Actualización: si cambiamos la categoría de una ciudad. mediante la descomposición de una relación inicial en otras tres. ya que se producen las siguientes anomalías: • Inserción: No podemos insertar los datos de un profesor hasta que éste no haya impartido un curso.000 25. Veamos ahora otro ejemplo de normalización. ya que al existir una sola dependencia. 389 C/Caimán. Supongamos esta vez que tenemos el esquema lógico de la Tabla 18. 52 .000 Domicilio C/ Alcala. que representa los cursos impartidos por un profesor. 28 Tabla 18 Este esquema no está normalizado.34 C/Caimán. sino sólo una vez en la relación 3. De este modo hemos conseguido eliminar las dependencias que se nos planteaban en la relación original: • • • Inserción: si queremos insertar un nuevo proveedor. ya que bastará con insertarlo en la relación 2.000 10. y domicilio de éste. Borrado: si borramos un reparto.000 15. Cod_post al 28027 28190 28027 28007 28190 Profesor Juan Pedro Juan Luis Pedro Fecha 01/02/99 03/02/99 03/02/99 01/02/99 03/03/99 Curso Windows 95 Visual Basic Windows 95 Delphi Windows 98 Precio 10. no hace falta que haga ningún reparto. 28 C/Alcala. 389 C/Remanso. no hace falta cambiarla en todas las filas.

sino sólo a una parte. Cada profesor vive en su domicilio. Diseño lógico • • Borrado: Si borramos la impartición del curso de Delphi.© Grupo EIDOS 4. perdemos los datos de dicho curso. identifica de manera unívoca cada fila de la relación. Por lo tanto. Procedemos de igual forma que en el ejemplo anterior. la relación se encuentra en 1FN. Lo primero es identificar la clave. el atributo precio no tiene dependencia funcional completa con respecto a la clave. dejando en una dicha dependencia junto con sus atributos. el atributo curso identifica el atributo precio. que en nuestro caso está compuesta por los atributos profesor. debemos hacerlo en dos filas y si modificamos el precio de un curso o el código postal de un domicilio. cod_postal curso Relación 2 Curso Tabla 20 precio curso Ya hemos eliminado la dependencia no completa de la clave para la anterior dependencia funcional. fecha. y del profesor que lo imparte. El atributo domicilio identifica el atributo cod_postal. fecha y curso. Pero todavía tenemos un atributo que depende de parte de la clave en la relación 1: 53 . Para cada valor diferente del atributo curso. desglosamos esta relación en otras dos. podemos existe un valor diferente para el atributo precio. ya que el conjunto de estos tres atributos. Actualización: Si modificamos la dirección del profesor Juan. cada domicilio tiene un código postal. El siguiente paso es identificar las dependencias funcionales. Atributos Profesor Fecha Curso Domicilio Cod_postal Curso Precio Dependencias Profesor domicilio Clave Relación 1 domicilio Profesor. El atributo profesor identifica unívocamente el atributo domicilio. y en la otra las demás. también. Tabla 19 Curso precio Profesor Domicilio domicilio cod_postal Ahora debemos comprobar si dicha relación cumple las reglas de cada una de las formas normales: • • 1FN: Puesto que para cada fila existe un solo valor para cada atributo. ya que tenemos la siguiente dependencia: curso -----> precio es decir. es decir. 2FN: Dicha relación no se encuentra en 2FN.

Atributos Relación 1 Profesor Domicilio Cod_postal Curso Precio Profesor Fecha Curso Tabla 21 Dependencias profesor domicilio curso Clave domicilio profesor cod_postal curso Profesor. podemos llevar cada una de ellas a una nueva relación. Atributos Relación 1 Relación 2 Profesor Domicilio Curso Precio Dependencias profesor curso domicilio precio Clave profesor curso 54 . ya que. no tiene dependencias no completas de ningún atributo no principal con respecto de la clave. fecha curso Relación 2 precio Relación 3 Esta relación ya se encuentra en 2FN. ya que la relación 1 tiene una dependencia transitiva con respecto de la clave: profesor domicilio domicilio cod_postal Como domicilio no depende de profesor. además de estar en 1FN. tenemos una dependencia transitiva del atributo cod_postal con respecto de la clave: profesor cod_postal Por lo tanto. una que contenga los atributos referentes a dicha dependencia y otra con los demás. con lo que nos queda lo que indica la Tabla 22. para romper esta dependencia. ya que en un mismo domicilio pueden vivir varios profesores. desglosamos la relación 1 en otras dos. Ahora podemos asegurar que el esquema se encuentra normalizado hasta la tercera forma normal. • 3FN: El anterior esquema no se encuentra en 3FN.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS profesor domicilio Por lo tanto.

Si tenemos que no se van a realizar prácticamente actualizaciones. Esto supone que puede que el esquema resultante de la normalización sea lo suficientemente eficiente como para que no sea preciso reestructurarlo. que no se queden dependencias en el camino.© Grupo EIDOS 4. a dejarlo como estaba. Como norma general. Sin embargo. Destacar. el proceso de desnormalización supone la unión de varias relaciones en un número menor de ellas. y una parte de esta estructuración es la normalización de relaciones. lo cual implica que se tardará menos en buscar la información. el lector puede preguntarse que para qué se procede a normalizar un esquema. Actualización: si cambiamos el precio de un curso. a medida que disminuya el nivel de normalización. si no que se van a realizar consultas sobre los atributos profesor. La respuesta es simple. esto es. En definitiva. se procurará que el esquema esté siempre normalizado al nivel de 3FN. Además. Un último detalle a tener en cuenta es el de la descomposición sin perdida de dependencias. o que simplemente no nos interese que el esquema sea eficiente. Diseño lógico Relación 3 Profesor Fecha Curso Domicilio Cod_postal Domicilio cod_postal Profesor. primero se procede a estructurar el esquema. pero que no presenta las anomalías que se daban en el original: • • • Inserción: si queremos dar de alta un nuevo curso lo haremos en la relación 2 y si queremos insertar un nuevo profesor. En estos momentos. y debido a aspectos de eficiencia. Borrado: si borramos la impartición de un curso. ya que el diseño será redundante. supóngase el ejemplo de los cursos visto en el apartado anterior. ya que se evitarán las anomalías expuestas. sólo se hará una vez. no perdemos la información de dicho curso. es decir. y que solo interese desnormalizar hasta otro determinado nivel. fecha curso domicilio Relación 4 Tabla 22 Lo que hemos conseguido es sustituir un esquema en el que sólo existía una relación. que mantiene la misma información. se puede proceder a realizar una reestructuración del esquema. Posteriormente. o del profesor que lo imparte. por último. interesará que el nivel de normalización sea bajo. para que el esquema original y el normalizado tengan la misma información. si el número de consultas es alto con relación al de actualizaciones. domicilio y cod_postal. parte de la cual supone la desnormalización del mismo. que interesa tener un nivel fuerte de normalización cuando el número de actualizaciones sea alto con relación al de consultas. lo haremos en la relación 1. en la relación correspondiente. en otro con cuatro. cuando posteriormente se va a desnormalizar. es frecuente que el número de relaciones disminuya. es decir. Por ejemplo. puede que normalicemos hasta un cierto nivel. Proceso de desnormalización El proceso de desnormalización hace referencia justo al proceso inverso de normalización que se acaba de ver. o el domicilio de un profesor. nos encontramos que para realizarla necesitamos acceder a dos 55 .

Atributos Relación 1 Profesor Domicilio Cod_postal Curso Precio Profesor Fecha Curso Dependencias profesor domicilio curso Clave domicilio profesor cod_postal curso Profesor. puede interesar en este caso desnormalizar dicho esquema un nivel. se deberá realizar un join. fecha curso Relación 2 precio Relación 3 Tabla 23 56 . es decir. con el aumento de tiempo de proceso que ello supone. donde para acceder a dicha información. simplemente se precisa consultar la relación 1.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS tablas (relación 1 y relación 4). Por lo tanto. hasta 2FN.

existen características que son comunes a la mayoría de los productos. debido a la carencia de un modelo formal. considerando los aspectos más cercanos al hardware. equivalente al relacional que permita una definición formal de esa fase de diseño. y que pueden ser utilizadas para definir un esquema físico. . pretendiendo los siguientes objetivos: • • • • • Disminuir los tiempos de respuesta Minimizar espacio de almacenamiento Evitar las reorganizaciones Proporcionar la máxima seguridad Optimizar el consumo de recursos Como ya se ha comentado. El diseño físico es fuertemente dependiente del producto comercial que se vaya a usar. es preciso llevar a cabo a cabo en muchas ocasiones un proceso de reestructuración de relaciones para conseguir una mayor eficiencia. es decir. características del SGBD. debido a la falta de flexibilidad de los actuales SGBD. los requisitos de procesos. hasta obtener un esquema aceptable. del Sistema Operativo y del hardware. que optimice el ratio coste / beneficios. Sin embargo.Diseño físico Introducción El diseño físico busca conseguir una instrumentación lo más eficiente posible del esquema lógico. lo que significa que se debe iterar desde el diseño lógico específico al físico y viceversa.

que representa la implementación del esquema lógico en un hardware específico. El SGBD impone una estructura interna. que es la unidad mínima que puede tratarse en una operación de Entrada / salida. Conceptos básicos sobre gestión de ficheros La unidad básica de las estructuras físicas (ficheros) es el registro físico. Híbrido entre ambos. y se obtienen como salidas una estructura interna. Inflexibilidad. Implica que el administrador de la base de datos pueda diseñar la estructura interna. Tiempo de seek: tiempo necesario para mover las cabezas al cilindro (conjunto de pistas del mismo diámetro) requerido. en la que se toman como entradas los recursos de la máquina. junto con unas normas de seguridad y unas especificaciones para el ajuste. a la par que se mantiene la independencia. Tiempo de latencia: tiempo que debe esperar hasta que el sector para por debajo de las cabezas. la forma de iterar entre la etapa de diseño lógico específico y la fase de diseño físico.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Se podría considerar el diseño físico como una caja negra. El tamaño de los bloques depende del producto comercial y del sistema operativo. De aquí podemos definir el factor de bloqueo para un fichero como el número de registros lógicos (o tuplas) por bloque para dicho fichero. lo cual supone un aumento de la eficiencia. El SGBD proporciona una estructura interna opcional que el diseñador puede cambiar con el fin de mejorar la eficiencia. 58 . información sobre las aplicaciones que se ejecutarán en la máquina así como los objetivos que se plantean en esta fase. 3. los recursos lógicos (SO. Tiempo de transferencia: tiempo necesario para transferir la información. si los datos son muy grandes. también denominado página o bloque. Entre las ventajas que supone utilizar esta técnica estriba la de que la BD puede empezar a funcionar de inmediato al disponer del esquema interno opcional. Las tuplas (en el caso del modelo relacional) se almacenan en dichos registros. Los bloques. Destacar que esta es la estrategia más utilizada en los actuales SGBD. con la posibilidad de ir mejorando sucesivamente la eficiencia al ir realizando ajustes. un registro lógico puede estar almacenado en varios registros físicos. 2. Es el contrapunto al anterior caso. La principal ventaja de esta estrategia es la independencia físico / lógica del esquema. etc. por el bus de datos. pudiendo almacenar cada uno de éstos varias de aquellas. impidiendo y dejando al administrador pocas opciones de cambiarlo. deben ser accedidos por el SGBD utilizando los mecanismos de gestión de ficheros que provee el sistema operativo. Flexibilidad. Estrategias en el diseño físico Existen tres tipos de estrategias que los fabricantes de SGBD imponen en sus productos comerciales: 1. el esquema interno resultará más ineficiente. a memoria principal.). El tiempo en acceder a un sector del disco. aunque por contra. oscilando éste entre 2 y 4 Kbytes. aunque también de la dependencia físico / lógica. está compuesto por varios factores: • • • • Tiempo de arranque: tiempo que tarda el disco en empezar a mover las cabezas. que es bastante elevado. Del mismo modo. el esquema lógico obtenido en la fase anterior. es decir. que se encuentran almacenados en los sectores del disco.

ya que soporta búsquedas por valores de clave.© Grupo EIDOS 5. que incide en un menor tiempo de respuesta. Es útil cuando las filas se recuperan por el valor de la clave. se suele usar un dispositivo de almacenamiento intermedio. puede que éste no quepa en el espacio reservado. el tiempo de acceso será instantáneo. es decir. las tablas son pequeñas o cuando se accede a casi todas las filas. cuyo cometido es el de almacenar los datos más usados. Número de bloques que se asignan a las extensiones. entre la que la más usada es la LRU (Least Recently Used). los datos que han sido usados más recientemente. Hash: Es una forma de organizar los ficheros teniendo como base una tabla indexada que apunta a la información. es decir. A la hora de acceder a dichos atributos. un índice (ya se verá más adelante lo que es) estorbaría. de forma que el acceso a los mismos se realice de una y otra forma: • Secuencial: El método de acceso es secuencial. ya que de todas maneras se necesita acceder a todas las filas. ISAM: Es una opción más amplia que la anterior. Porcentaje de utilización de cada bloque. denominado caché o buffer. aprovechando de este modo la ley de proximidad temporal. los datos próximos tienen mayor probabilidad de ser referenciados. Otra política es aprovechar la ley de proximidad referencial. que en este caso actúa como función para determinar la posición donde se encuentra la información. Al modificar un valor de un atributo. Un índice se puede 59 . evitando de este modo accesos extra a disco. • • • Técnicas para el aumento de eficiencia Existen varias técnicas para aumentar la eficiencia del esquema: • Índices: Se puede definir un índice como una estructura que sirve para mejorar la eficiencia de las consultas a una base de datos. Se pueden agrupar determinado número de bloques contiguos en unidades llamadas extensiones. De esta forma se evita la concatenación de bloques. es decir. es decir. Árbol B+: Es una estructura que soporta búsquedas dicotómicas (el número de búsquedas es menor que log2 n). utilizando diversas políticas. • • Organización de ficheros Existen varias formas de organizar los ficheros. Diseño físico Para acelerar este proceso. es decir. Algunos SGBD permiten especificar las características de los registros físicos. Los parámetros que se pueden especificar son: • El porcentaje de espacio libre que se deja en cada bloque para albergar posteriores actualizaciones de los registros lógicos. los bloques que se han usado hace más tiempo. Un índice se define sobre uno o varios atributos. son candidatos a desalojar la caché para albergar otros bloques. tienen una alta probabilidad de que sean usados en un futuro cercano. Es conveniente usar esta forma de organización cuando existe una carga masiva de datos. un registro detrás de otro. además de por parte de ella o usando patrones de búsqueda. Este dispositivo es gestionado por el sistema operativo. La ventaja con respecto al caso anterior es que crece de forma dinámica.

se suele indexar la clave primaria (mediante un índice único. la de nombre Rafael y equipo Deportivo. o aquellos atributos que no vayan a ser modificados. reduciéndose en este caso el número de accesos a dos. Sin embargo no todo son ventajas. y que no van a ser alterados No indexar tablas pequeñas No indexar tablas que se van a recorrer secuencialmente . ya que cuanto mayor sea esta estructura. se realizarían siete accesos (toda la tabla). podemos acceder a la página del libro de forma inmediata.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS comparar con el índice de un libro. encontrándose dos jugadores que cumplen este requisito. supóngase que tenemos la relación que muestra la Tabla 24. Madrid Barcelona Valencia R. Sin embargo si tuviésemos un índice combinado para los atributos Nombre y Equipo. es decir. solo se realizaría un acceso. es decir. Ya se ha visto entonces la ventaja de usar este tipo de estructuras para acceder rápidamente a la información. se encontraría una única fila. los accesos serían inmediatos a las dos únicas filas que cumplen este requisito. se deberá acceder a todas las filas. Sin embargo. si se dispone de un índice por el atributo Nombre. pero se debería acceder a dos. es decir los atributos de una tabla que son clave que otras tablas Indexar aquellos atributos que se van a consultar con más frecuencia. Si ahora se desea buscar todas las filas con el nombre de Rafael. mayor espacio de almacenamiento será necesario. es decir. Madrid At. deberemos ir mirando hoja por hoja hasta encontrar la página deseada. La siguiente lista resume una serie de consejos a la hora de indexar campos: • • • • • 60 Indexar la clave primaria con un índice único Indexar las claves ajenas. Bilbao Deportivo Si en este momento se desea hacer una consulta sobre todos los jugadores que se llamen Fernando. sin contar el tiempo que se pierde en actualizar el índice cuando se modifica algún valor de los atributos que forman parte de él. si disponemos de dicho índice. Si tuviésemos un índice por el atributo Nombre. y que pertenezcan al Deportivo. se han realizado siete accesos. Por ejemplo. que no permita valores repetidos). mientras que si no lo tenemos. Por este motivo. Vázquez Tabla 24 Equipo Valencia R. Cod_jugador 10 20 25 30 49 80 90 Nombre Adrián Fernando José Claudio Fernando Rafael Rafael Apellido Illie Redondo Guardiola López Hierro Alkorta M. las filas cuyo nombre es Rafael.

Sin embargo. La forma más segura de controlarlo es mediante disparadores o triggers. es decir.© Grupo EIDOS 5. se requiere un mayor tiempo de proceso debido a la necesidad de descomprimir los datos que se recuperan. que cambien el valor de todos los atributos duplicados. 61 . cuando cambia uno de éstos. Sin embargo. Esta técnica supone una desnormalización física de las tablas. pero que lógicamente siguen siendo dos tablas independientes. que se encuentran físicamente agrupadas. se debe garantizar la consistencia de la base de datos. esta redundancia debe ser controlada. por lo que el agrupamiento será transparente al usuario. Figura 35 Con este método se consigue mejorar la eficiencia en la consulta simultanea de ambas tablas. • Compresión de datos: Por un lado. la compresión de datos permite reducir el espacio requerido para almacenar la información. con el fin de evitar accesos a tablas consultadas frecuentemente. • Redundancia de datos: La redundancia de datos consiste en duplicar el valor de ciertos atributos de una tabla en otra. que consiste en almacenar la diferencia entre el valor de un atributo y el que le precede. La Figura 35 muestra un agrupamiento de dos relaciones Empleado y Departamento. pero empeora cuando se recorren de forma separada. Diseño físico • • No indexar atributos de tipo carácter muy largos Agrupamiento o "clustering": Se entiende por "clustering" de tablas la agrupación de tablas cuyas filas comparten un grupo de atributos llamado clave de agrupamiento. La técnica de compresión más utilizada es la de compresión diferencial. lo que radica en un menor número de operaciones de Entrada / salida.

.

desarrollado por Microsoft. etc. . el lenguaje de definición de datos (DDL). ¿Por qué se llama SQL Server?. la gestión de un entorno de bases de datos relacional. éste no la entendería. índices. si ejecutamos una sentencia del conjunto adicional (Transact SQL) en otro SGBRD. se llama SQL porque utiliza este lenguaje para la definición y manejo de los datos.Introducción a SQL Server ¿Qué es SQL Server? SQL Server es un Sistema de Gestión de Bases de Datos Relacionales (SGBDR). así como la consulta. tablas. que permite. como la de administración. y se llama Server porque dispone de una parte servidora que se encarga de atender a los procesos clientes.. pero además se le han añadido ciertas funciones adicionales. tanto el área de diseño. es decir. y que son específicas para este producto. proporcionando un interfaz bastante amigable con el usuario. sigue una arquitectura cliente/servidor. que se denomina Transact SQL. soporta la definición. que son los que realizan las peticiones a éste. el lenguaje de manipulación de datos (DML). SQL Server utiliza una extensión al SQL estándar. actualización y borrado de tuplas de tablas. es decir. no contempladas en el estándar. atributos. modificación y eliminación de bases de datos. es decir. El Transact SQL. Pues bien. Esto quiere decir que soporta el SQL de ANSI. SQL Server abarca. como su propio nombre indica. es decir.

SQL Server fue avanzando. Sin embargo. supuso una revolución en el mundo de las bases de datos para PC. Por aquel entonces. El interfaz de acceso a bases de datos por excelencia. ante el boom del PC. obliga a pensar si SQL Server puede ser útil para manejar y/o obtener datos de la red de redes. La aparición de Internet. destinado a investigar el modelo relacional. pero ni por asomo podían ser utilizadas en los PCs. la aparición de dBase. los SGBD relacionales más vendidos resultan ser ORACLE y SQL Server. La verdad es que las interfaces de acceso a bases de datos. (RSI). IBM y Microsoft se comprometieron a desarrollar un nuevo entorno. 64 . los cuales hacen todo el trabajo de traducción. con el fin de adecuarse a las necesidades cambiantes del mercado. a la vez que han ido apareciendo otros nuevos. Cuando surgió aquella maquina que hoy denominamos PC. A su vez. Ashton-Tate. dirigido a las bases de datos. Este hecho supuso el nacimiento de SQL-Server. ORACLE fue el nombre que se le dio a un proyecto. deciden aliarse para sacar un nuevo producto al mercado: una base de datos relacional. sobre todo durante estos últimos años. ODBC ofrece una serie de métodos encapsulados. La combinación de éste con SQL Server. sobre todo con ORACLE. se pueden mostrar datos en un navegador de Internet. que no tiene por qué saber las características de ésta. nadie podía imaginar que iba a desbancar de su puesto a las grandes plataformas como el Sistema 36 de IBM o el VAX de Digital. ante la falta de resultados positivos. se decidió cancelar el proyecto. Microsoft y Sybase. de Ashton-Tate. que significa Open Database Connection (Conexión abierta a Bases de Datos). En 1979. por ejemplo. ha sido siempre ODBC. SQL Server e Internet El impacto que. y le dieron el nombre de OS/2. Sin embargo. capaz de soportar SQL-Server. originando una batalla para ganar posiciones en este mercado. A su vez. Desde entonces y hasta hoy. pero en este caso se ofrecen una serie de funcionalidades especiales para adaptarlo al lenguaje Java. adecuado al lenguaje Java. Su cometido es el mismo que ODBC. En el año 1988. por aquel entonces algo utópico. supuso el nacimiento de un nuevo interfaz. que fue la primera base de datos relacional en utilizar el lenguaje SQL. ORACLE. RSI lanzó al mercado la versión 2 de ORACLE. y venderlo a Relational Software Inc. empezaban a implantarse las bases de datos relacionales. llamado JDBC.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Orígenes Como podemos comprobar. adaptándose a las nuevas tendencias del mercado. obtenidos de una base de datos SQL. otra forma de acceder a una base de datos desde Internet es la ofrecida por un producto llamado Microsoft Internet Information Server (IIS). también han ido experimentado un largo y constante cambio. IBM. Fue un poco más tarde cuando RSI decidió cambiar su nombre por el de su producto estrella. Sin embargo. Fue entonces cuando la aparición de Windows NT reemplazó a OS/2 como soporte para SQL Server. ha venido sufriendo el uso de Internet. principios de los ochenta. Mediante esta forma. el mercado de la informática ha ido cambiando sorprendentemente desde hace unos pocos años. y que supone la abstracción por parte del usuario que quiere acceder a la base de datos. para PC. ofrece una potente forma de unir SQL e Internet.

Veremos en este capítulo las mejoras que ha sufrido esta nueva versión. con respecto a las anteriores. Nuevas características Entre las nuevas características que ofrece SQL-Server 2000. Particionamiento horizontal de relaciones y gestión de vistas distribuidas. Funciones de usuario. Indexación de vistas. La Figura 36 muestra la arquitectura general de este SGBD. sobre todo al entorno remoto y distribuido. .Lo nuevo en SQL-Server 2000 Introducción Como decíamos. SQL-Server ha ido evolucionando a lo largo de los últimos años. La apuesta de Microsoft por este SGBD ha sido (y es) bastante fuerte. cabe destacar las siguientes: • • • • • Soporte para XML. Soporte para Virtual Interface Architecture (VIA). lo cual ha hecho posible la mejora y adaptación del mismo. mejoras que pasamos a detallar a continuación.

Bases de datos con SQL Server 2000 – Transact SQL

© Grupo EIDOS

• • • • • •

Nuevos tipos de datos. Nuevos triggers. Reglas de integridad referencial en cascada. Nuevas características de indexación. Soporte para consultas distribuidas. Características de seguridad y cifrado de datos.

Figura 36

Soporte para XML
El Extensible Markup Language, más conocido como XML es un metalenguaje, es decir, un lenguaje utilizado para definir lenguajes, y que se usa sobre todo para el intercambio de datos. Su sintaxis es similar a la que nos ofrece el HTML, es decir, un conjunto de etiquetas que definen la estructura de los datos. El Código fuente 2 define un posible formato de intercambio.
<cliente> <nombre>Pepe</nombre> <apellidos>Lopez</apellidos> <telefono>912345678</telefono> </cliente> Código fuente 2

66

© Grupo EIDOS

7. Lo nuevo de SQL - Server 2000

SQL-Server 2000 ofrece la posibilidad de devolver un conjunto de resultados utilizando para ello este tipo de formato, facilitando así el intercambio de datos.

Particionamiento horizontal de relaciones y gestión de vistas distribuidas
Otra de la características nuevas que nos ofrece SQL-Server 2000 es la posibilidad de particionar horizontalmente los datos de una relación. Ya se ha comentado lo útil que es este tipo de reestructuración de relaciones, sobre todo en el ambiente distribuido, en el cual se pueden colocar las tuplas en los servidores que se supongan más posibilidades tengan de consultarlas en forma local. Del mismo modo, se pueden definir vistas distribuidas que accedan a estos datos, en cada uno de los servidores que nos interese, de manera que la ejecución de la misma dé la impresión de estar interactuando sobre un conjunto completo de resultados.

Soporte para Virtual Interface Architecture (VIA)
SQL-Server 2000 introduce nuevas librerías de red, que permiten definir un entorno distribuido de forma eficiente, posibilitando una gran conectividad, tanto de servidores como de aplicaciones, en este tipo de entornos.

Funciones de usuario
Una funcionalidad nueva que aparece en esta versión del SGBD es la de permitir al usuario definir sus propias funciones. De esta forma se pueden definir funciones que oculten parte de la complejidad que puede entrañar una consulta, no sólo para la posterior reutilización de la misma, sino también teniendo en cuenta la abstracción para otros programadores que puedan precisar su uso.

Indexación de vistas
Esta funcionalidad permite optimizar la ejecución de vistas que actúan sobre la base de datos, creando índices sobre los resultados de ejecución de la misma, que son almacenados en la base de datos. El usuario no debe preocuparse de la actualización de los datos, sino que éstos son indexados automáticamente cada vez que se actualicen.

Nuevos tipos de datos
SQL-Server 2000 soporta tres nuevos tipos de datos con respecto a la anterior versión, la 7, que son el bigint o entero de 8 bytes, sql_variant, que soporta el almacenamiento de valores de distintos tipos, y table, que permite el almacenamiento temporal de resultados para su uso posterior.

67

Bases de datos con SQL Server 2000 – Transact SQL

© Grupo EIDOS

Nuevos triggers
Un trigger o desencadenador es un código especial que se ejecuta cuando se cumple una determinada condición, como por ejemplo al modificar o borrar datos (se verá en detalle en un capítulo posterior). SQL-Server 2000 soporta dos nuevos tipos de triggers, que son INSTEAD OF y que sustituye el comportamiento de ciertos comandos, como por ejemplo insert, update o delete, y AFTER, que se ejecuta una vez concluida la acción que lo ha desencadenado.

Reglas de integridad referencial en cascada
Las reglas de integridad referencial son la base del mantenimiento de la consistencia en la base de datos, y hacen referencia a información que esta relacionada entre si, como por ejemplo el departamento de un empleado cuyo código se especifica. La forma más usual de mantenerlo es usando claves foráneas, y especificando el comportamiento de las inserciones, borrados y actualizaciones de este tipo de datos.

Nuevas características de indexación
Las nuevas características de indexación permiten crear índices sobre campos calculados (no existen como tal en la base de datos, sino que se calculan a partir de otros valores), así como especificar si se desea construir estos índices de manera paralela, lo que aumenta la velocidad de procesado.

Soporte para consultas distribuidas
El optimizador de consultas ofrece la funcionalidad de ubicar datos en servidores distribuidos, dependiendo de valores tales como el nivel de carga, el tráfico de red, etc., de manera que las consultas pueden acceder a distintos servidores para obtener el resultado final.

Características de seguridad y cifrado de datos
SQL-Server 2000 utiliza Kerberos como servidor de autenticación, para acreditar el acceso al servidor que se realiza desde el cliente, así como diversas técnicas de seguridad.

68

Instalación de SQL Server 2000
En este capítulo, veremos como instalar SQL Server 2000, y las distintas opciones que plantea. Para empezar, introduzca el CD-ROM que contiene el programa. Si no arranca automáticamente, utilice el explorador para ejecutar el fichero autorun contenido en el CD-ROM. Tenemos dos opciones, la standard o la personal. La primera de ellas realiza una instalación completa, incluyendo los componentes servidor, mientras que la segunda es útil en el caso de que no dispongamos de un servidor. La primera pantalla que aparece es la que se muestra en la Figura 37.

Figura 37

En principio. en el cual se haya instalado la versión 5. visualizándose la pantalla que se muestra en la Figura 39.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS En nuestro caso instalaremos la opción standard (si no disponemos de un servidor. Figura 39 70 . únicamente se instalarán los componentes cliente). pulsamos la opción SQL Server 2000 Components.5 del navegador WEB Microsoft Internet Explorer. apareciéndonos la pantalla que muestra la Figura 38. Para proseguir la instalación. el único requisito que se necesita es disponer de un equipo con al menos 64 Mb de memoria RAM (recomendable 128 Mb) y sistema operativo Windows 98/NT/2000. Figura 38 Pulsamos el botón Next.

Server 2000 En este caso. donde se nos insta a poner nuestro nombre y compañía. visualizaremos la siguiente pantalla que muestra la Figura 40 Figura 40 Nuevamente. sólo se nos permite seleccionar la opción de crear una nueva instancia de SQL Server. al estar instalando la versión standard en un equipo con Windows 98. puesto que queremos instalar los componentes cliente en nuestro equipo local. Pulsando el botón Next. obtendremos la pantalla que se muestra en la Figura 41. Instalación de SQL . Si pulsamos el botón Next.© Grupo EIDOS 8. Figura 41 71 . sólo nos permite la selección de esta opción.

accederemos a la pantalla de la Figura 44. cuyo cometido es el de mostrarnos las condiciones de uso de la licencia. 72 . en la que podemos seleccionar los componentes y subcomponentes a instalar. Figura 42 Figura 43 Seleccionando la opción de instalación de las herramientas cliente y pulsando el botón Next. podremos visualizar la pantalla que se muestra en la Figura 42.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Si pulsamos nuevamente el botón Next. pulsamos Yes para pasar a la siguiente pantalla que se indica en la Figura 43.

Server 2000 Figura 44 Dejamos marcados los que vienen por defecto y pulsamos el botón Next. para acceder a la página de la Figura 45. tras la cual el sistema empezará a instalar los componentes seleccionados y. como muestra la Figura 46. tras unos minutos. Instalación de SQL .© Grupo EIDOS 8. mostrará la pantalla final en la cual se nos informa de la conclusión del proceso de instalación. Figura 45 73 .

Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Figura 46 74 .

y accederemos a la opción Diagramas (Diagrams) de la base de datos deseada dentro del grupo Bases de datos (Databases). tal y como se plasmarían las relaciones en tablas. Para acceder a esta herramienta. como muestra la Figura 48. seleccionaremos la opción New Database Diagram del menú contextual que aparece al hacer click con el botón derecho del ratón sobre esta pantalla. como muestra la Figura 47. sino a nivel lógico. las restricciones.El modelo E/R en SQL-SERVER 2000 Introducción SQL-Server nos ofrece una herramienta para realizar diseños relacionales. . En la parte derecha podremos observar como aparecen todos los diagramas disponibles para la base de datos seleccionada. es decir. etc. deberemos acceder a la opción del Administrador corporativo o Enterprise manager. Una vez dentro. bastará con hacer doble click con el ratón sobre el. mientras que para crear uno nuevo. Para acceder a uno de ellos. pudiendo además especificar cuestiones como la integridad referencial. pero no a nivel conceptual. daremos de alta el registro de servidor (si no se encuentra ya hecho).

Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Figura 47 Figura 48 76 .

Figura 49 Figura 50 77 . que no es más que la primera página de un asistente que nos guiará durante el resto del proceso de creación del diagrama. como la de la Figura 49. El modelo E/R en Sql-Server 2000 Crear un nuevo diagrama Vamos a crear ahora un nuevo diagrama. que se muestra en la Figura 50. Pulsamos el botón Siguiente para avanzar al siguiente paso.© Grupo EIDOS 9. para lo cual actuamos como se acaba de comentar. Nos aparecerá entonces una ventana.

tablas relacionadas de tablas relacionadas. pulsando el icono en forma de disco de la barra de herramientas. junto con el nombre de sus atributos. En el podemos observar las tablas que hemos seleccionado.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS En la parte izquierda nos aparecen todas las tablas disponibles. y las relaciones entre ellas. Vamos a guardar nuestro diagrama. habremos de pulsar el botón Remove. y ya tenemos nuestro diagrama. Figura 51 Este es el último paso. Una vez seleccionadas todas la tablas que deseamos pasen a formar parte del diagrama (en nuestro caso escogemos las tablas authors. en el que se nos muestran las tablas que hemos seleccionado. las claves (que aparecen con un icono en forma de llave). Pulsamos el botón Finalizar. que se muestra en la Figura 51. mientras que para eliminarla del mismo. para trabajar posteriormente con el. 78 . mientras que en la derecha tenemos las tablas que nosotros seleccionaremos para pasar a formar parte de nuestro diagrama. pudiendo además especificar el número de niveles que se incluirán. La forma de añadir una tabla al diagrama es seleccionándola y pulsando el botón Add. como el lector ya habrá podido adivinar. titleauthor y titles). Estas relaciones muestran las dependencias existentes entre ellas. Esta opción es muy útil para chequear restricciones de una tabla que no sabemos con cuales se relaciona. es decir. pulsamos el botón Siguiente para avanzar al próximo paso. La caja de selección que aparece en la parte inferior bajo el nombre Add related tables automatically permite añadir todas las tablas relacionadas con las seleccionadas de manera automática. y dándole un nombre coherente. que tendrá un aspecto similar al mostrado en la Figura 52.

para establecer este tipo de reglas. existe otra manera mucho más cómoda. Sin embargo. Para visualizar este tipo de características.© Grupo EIDOS 9. 79 . apareciéndonos una pantalla similar a la de la Figura 53. En la pestaña Indexes/Keys es donde se especifican aspectos referentes a los índices que van a hacer referencia a los atributos de la tabla. y el atributo que actúa como clave ajena dentro de la tabla destino y le damos un nombre a dicha restricción. Para ello debemos indicar el atributo que actúa como clave primaria dentro de la tabla origen. sin soltarlo. Dentro de la pestaña Relationship se pueden especificar restricciones y características tales como la integridad referencial. y cuyo aspecto es el mostrado en la Figura 54. arrastrarlo hasta la tabla que contiene la clave primaria con la cual se relaciona. que es seleccionar con el ratón el atributo que es clave ajena dentro de una tabla y. El modelo E/R en Sql-Server 2000 Figura 52 Restricciones e integridad referencial Una de las principales utilidades que nos ofrece esta herramienta es la de establecer las restricciones y las reglas de integridad referencial de una manera fácil y visual. dentro de la tabla o relación deseada. pulsamos con el botón derecho del ratón en la opción Propiedades (Properties) del menú contextual.

Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Figura 53 Figura 54 80 .

cluster. definidos sobre uno o varios atributos. añadir o borrar tablas o atributos del diagrama (existentes o nuevas). Figura 55 Modificación del esquema Aparte de definir restricciones. inserciones y actualizaciones. especificando mediante una expresión regular que dicho atributo deberá ser rellenado con 9 dígitos. El índice primario hará referencia a la clave primaria de la relación. etc. en la Figura 55 se especifica una restricción sobre el atributo clave de la tabla. Por ejemplo. y que se aplicará en las replicaciones. nuevamente habrá que escoger la opción correspondiente haciendo click con el botón derecho del ratón.© Grupo EIDOS 9. Dentro de la pestaña Check Constraints podemos indicar las restricciones sobre los atributos de la tabla. la herramienta de diagramas también nos da la posibilidad de realizar modificaciones del esquema. crear nuevas relaciones. de tipo ascendente o descendente (se refiere a la ordenación). esto es. como de tipo único. Para ello. El modelo E/R en Sql-Server 2000 En esta pantalla podemos crear o borrar índices. etc. 81 . aunque también podemos especificar otro tipo de índices. cambiar el tipo o el nombre de los mismos. como muestra la Figura 56.

Para ello pulsamos con el ratón el atributo stor_id en la tabla authors y. el nombre de un atributo. como muestra la Figura 57. sin soltarlo. mostradas en la Figura 60 Figura 57 82 . vamos a añadir la relación con una existente. Ya tenemos la relación entre ambas tablas. para practicar lo aprendido hasta ahora. por ejemplo. sólo tendremos que confirmarlo ante la pantalla que nos aparece en la Figura 58. Una vez que aparezca la tabla seleccionada en el diagrama. Lo primero es seleccionar la opción Add Table del menú contextual y seleccionar la tabla existente en el esquema que deseamos añadir al diagrama. podemos observar las restricciones y las reglas de integridad aplicables a la misma. Crear una nueva relación Una vez vistos los principales conceptos en la creación de diagramas. nos movemos a la tabla stores. y escoger la pestaña Columns. Si hacemos click derecho y escogemos la opción propiedades sobre la nueva relación creada.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Figura 56 Otra de las formas de modificar. vamos ahora a crear una nueva relación con una tabla existente. El diagrama resultante es el mostrado en la Figura 59. o cambiar el tipo haciendo click derecho en el atributo y escogiendo la opción de propiedades. es pulsando sobre el y escribiendo directamente el nuevo sobre la tabla.

© Grupo EIDOS 9. El modelo E/R en Sql-Server 2000 Figura 58 Figura 59 83 .

Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Figura 60 84 .

Disconnect: Cierra la conexión a la base de datos en uso. Su apariencia es la que muestra la Figura 61.El analizador de consultas Introducción El analizador de consultas (o query analizer) es la herramienta que permite editar y ejecutar sentencias de T-SQL. Podemos observar en ella un editor. podemos encontrar las siguientes: • • • • • • Connect: Abre una nueva conexión a una base de datos. y una barra de herramientas con iconos de acceso rápido a ciertas utilidades. Open: Abre un archivo de SQL existente. Las opciones de menú Entre las opciones que ofrece el menú File. una barra de menú. con las opciones disponibles. . pero para todas las conexiones abiertas New: Abre una nueva ventana dentro del editor. Disconnect all: Idem que el anterior. que sirve para ejecutar las sentencias. Save: Guarda a un archivo la ventana del editor en uso.

Print: Imprime la ventana en uso del editor. Save all queries: Idem que el anterior. pero para todas las ventanas abiertas en el editor. Exit: Cierra el analizador de consultas. Recent file list: Muestra una lista con los archivos más recientemente usados. pero con la posibilidad de indicar un nombre de archivo.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS • • • • • Save as: Idem que el anterior. Figura 61 Figura 62 En el menú Edit podemos encontrar las siguientes opciones: 86 .

campos. dentro de la ventana en uso del editor. • • Figura 63 87 . Además SQL-Server nos ofrece plantillas predeterminadas. etc. que se ajusten a sus necesidades. es dccir.© Grupo EIDOS 10. Advanced: Opciones avanzadas de edición. Paste: Pega el contenido del portapapeles a la ventana en uso del editor. El analizador de consultas • • • • • • • • • • • • Undo: Deshace el último cambio realizado en el texto de la ventana en uso del editor. Copy: Copia el texto seleccionado al portapapeles. rellenarla con las tablas. para cada uno de los casos más representativos (creación de vistas. Select all: Selecciona todo el texto de la ventana en uso del editor. Go to line: Mueve el cursor a una línea determinada. dentro de la ventana en uso del editor. Bookmarks: Permite manejar los bookmarks.). muy util para sentencias repetitivas. pero para buscar varias coincidencias. Repeat last find: Idem que el anterior. etc. Insert template: permite añadir una plantilla de una sentencias. Clear window: Borra todo el contenido de la ventana en uso del editor. Find: Busca un texto determinado dentro de la ventana en uso del editor. para su mejor identificación. o marcas dentro del texto de las sentencias a ejecutar. procedimientos almacenados. Replace: Reemplaza un texto por otro. Replace template parameters: Permite al usuario cambiar los parámetros dentro de una plantilla. ahorrando al programador la mayor parte del trabajo. Cut: Corta el texto seleccionado al portapapeles.

etc. Index tunning wizard: Permite realizar el ajuste o “tunning” (cuyo concepto ya ha sido visto en los primeros capítulos) de los índices de una base de datos concreta. Results to file: Si está marcada esta opción. desglosando en pasos cómo se ejecutará la consulta. Por último la opción Help ofrece una completa ayuda tanto del editor. en mosaico. el plan real de ejecución de ésta. Parse: Compila la consulta del editor. verificando su sintaxis. Cancel executing query: En el caso de que se esté ejecutando una consulta. Results in grid: Si está marcada esta opción.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Dentro del menú Query nos encontramos con las opciones disponibles. y mostrando errores si no cumple con ésta. los resultados de la consultas serán enviados a un archivo. • • • • • • • • Por su parte. Execute: Ejecuta la consulta del editor. Show client statistics: Si esta opción está marcada. La Figura 65 indica un posible plan de ejecución para una consulta concreta. Display estimated execution plan: Muestra el plan previsto. es decir. esta opción muestra. Si la opción display estimated execution plan nos enseñaba el plan estimado. Current connection properties: Muestra información acerca de la actual conexión a la base de datos. En particular. la opción de menú Tools muestra opciones referentes a herramientas que se pueden usar para configurar diversas opciones referentes al editor o ejecución de consultas. para colocarlas en cascada. relacionadas con la edición y ejecución de consultas: • • • • • Change Database: Permite cambiar la actual conexión a una base de datos por otra. vista desde la parte cliente. pasos de la ejecución. 88 . se muestra información acerca de la traza de ejecución de la consulta en el servidor. La opción Window permite manejar las ventanas que se encuentran dentro del editor. una vez realizada. los resultados de la consulta serán mostrados en formato textual. esta opción arranca un asistente para realizarlo. La Figura 66 muestra una posible traza de ejecución en el servidor de una sentencia select de ejemplo. se muestra el plan de ejecución de la consulta. Results in text: Si está marcada esta opción. Show server trace: Si esta opción está marcada. Una posible estadística es la mostrada en la Figura 67. se muestran estadísticas de ejecución de la consulta. consumo de procesador. junto con los resultados. etc. como cuestiones diversas sobre T-SQL. permite detenerla. separados por filas y columnas. Show execution plan: Si esta opción esta marcada. los resultados de la consulta serán mostrados en una rejilla o grid. número de lecturas/escrituras. navegar entre ellas.

El analizador de consultas Figura 64 Figura 65 89 .© Grupo EIDOS 10.

Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Figura 66 Figura 67 90 .

Muestra el plan estimado de ejecución de la consulta Muestra una lista de los objetos del sistema Permite realizar una búsqueda de los objetos del sistema Muestra información acerca de la actual conexión Muestra el panel de resultados de la ejecución de la consulta 91 .© Grupo EIDOS 10. El analizador de consultas La barra de herramientas Crea un nueva consulta. Ejecuta la consulta. Abre una consulta existente en un archivo Guarda la consulta del editor en un archivo Introduce una plantilla de consulta en el editor Corta el texto seleccionado al portapapeles Copia el texto seleccionado al portapapeles Pega el texto almacenado en el portapapeles Borra el contenido de la ventana del editor Busca un texto determinado en la consulta del editor Deshace el último cambio realizado en la consulta del editor Permite seleccionar la forma en que se mostrarán los resultados (en texto. Detiene la ejecución de una consulta. trazas de servidor y estadísticas de cliente). rejilla o archivo) y la información adicional (plan de ejecución. pudiendo utilizar para ello una plantilla. Permite seleccionar la base de datos. Compila la consulta para verificar su sintaxis.

La de arriba contiene la sentencia a ejecutar. Ejecutamos nuevamente. Probemos ahora a mostrar los resultados en forma de tabla. como muestra la Figura 68. En ella podemos apreciar como se nos ha dividido el editor en dos partes. por ejemplo pubs. tecleando el servidor (si no se pone nada se accederá al servidor local) y el login y password. escogiendo la opción Execute del menú Query. SELECT * FROM titles Código fuente 3 A continuación ejecutamos la sentencia. Figura 68 Una vez hecho esto. haciendo click en el botón en forma de flecha verde de la barra de herramientas. Escogemos una de ellas. y lo que nos aparece ahora es una ventana como la que muestra la Figura 70. ya que entraremos en detalle en posteriores capítulos). 92 . Para ello accederemos al analizador de consultas. Para ello seleccionamos la opción Results in grid del menú Query. ya tenemos acceso a todas las bases de datos existentes en el servidor. y dentro del editor tecleamos el Código fuente 3. o tecleando F5. cuyo cometido es mostrar todos los valores de todos los atributos de la tabla titles. mientras que la de abajo muestra los resultados de la ejecución de la misma.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Ejecutando una consulta Pongamos ahora en práctica los conceptos aprendidos ejecutando una consulta sencilla (no debe preocuparse si todavía no entiende nada de código. Lo que nos aparecerá será una ventana como la de la Figura 69.

el mensaje que indicaba el número de registros devueltos aparece ahora en otra pestaña en la parte inferior. Esta pestaña no sólo sirve para visualizar el 93 . El analizador de consultas Figura 69 Figura 70 En ella podemos observar como lo que antes nos aparecía en forma de texto. con una salvedad.© Grupo EIDOS 10. ahora nos aparece en un grid. nombrada como Messages.

como muestra la Figura 72. tal como se puede observar en la Figura 71. sino muestra otro tipo de mensajes. guardaremos nuestra pequeña consulta en un archivo. y escogiendo un nombre para el mismo.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS número de registros seleccionados. Figura 71 Por último. como por ejemplo los de error. para lo cual seleccionaremos la opción Save as del menú File. Figura 72 94 .

seleccionamos con el ratón el rango de resultados que deseemos exportar y hacemos clic con el botón derecho del ratón para seleccionar la opción Save as.© Grupo EIDOS 10. y la forma de exportación y separación de campos. Para ello. y estando en el modo de Results in grid. El analizador de consultas Otra de las posibilidades que nos ofrece SQL-Server es la de exportar los datos que hayamos obtenido en una consulta. Nos aparecerá una ventana como la de la Figura 73. en la que deberemos dar un nombre al archivo. Figura 73 95 .

.

. borrar o actualizar atributos. actualizar. añadir. Lenguaje de Definición de Datos (DDL): permite establecer y/o modificar el esquema relacional. existen dos tipos de sentencias. Si el lector encuentra alguna terminología un tanto desconocida. La Tabla 25 muestra una descripción de éstos. o borrar información. con diferente cometido. es decir. que permiten mantener dicho esquema: • • Lenguaje de Manipulación de Datos (DML): permite manipular los datos del esquema relacional. tablas. consultar.El lenguaje de definición de datos (DDL) Introducción Como ya se vio en la anterior parte acerca del diseño de esquemas relacionales. índices. ya que en un próximo capítulo se describirán con detalle los operadores básicos que ofrece Transact SQL. En este capítulo se verá este último. dejando el primero para otro posterior. así como algunas consideraciones acerca del lenguaje. Estos tipos de datos serán utilizados a la hora de definir los atributos de una tabla. no se preocupe. etc. es decir. Tipos de datos Existe una amplia variedad de tipos de datos que podemos utilizar en Transact SQL.

23E-308 hasta -1.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Identificador en SQL Server Int bigint Smallint Tinyint numeric(p. Declarable hasta un máximo 1 byte por carácter de 255 caracteres usado.5507 4 bytes 98 . Doble precisión.147. Números con Desde una precisión de 922.18E-38 hasta -3.685.79E308 hasta +1.337. Declarable hasta un máximo 1 byte por carácter de 255 caracteres declarado. Simple precisión.337. Números con una precisión de cuatro decimales. Espacio consumido fijo.203.79E308 Precisión negativa: desde 2.79E308 hasta +1. Espacio consumido variable 8 bytes varchar(n) money smallmoney Moneda. donde n está comprendido entre 1 y 7.40E38 hasta +3.23E-308 hasta 1.s) Descripción Entero Entero largo Entero corto Rango de valores Desde -2.79E308 en donde p es el número de dígitos de la parte entera (precisión) y s es el de la parte decimal (escala) Redondeos de números desde -1.447.647 Tamaño 4 bytes 8 bytes Desde -32. Precisión positiva: desde 1.483. Precisión positiva: desde 2. 8 bytes real numérico de coma flotante con redondeo. 4 bytes char(n) Alfanumérico de longitud fija Alfanumérico de longitud variable Moneda.5508 cuatro decimales.203.40E38. hasta 922.s) decimal(p.40E38 Precisión negativa: desde 1.767 2 bytes 1 byte de 2 a 17 bytes dependiendo de la precisión especificada Entero minúsculo (sin Desde 0 hasta 255 signo) decimal exacto sin redondeo Enteros y decimales desde 1.18E-38 hasta 3.40E38 float(n) numérico de coma flotante con redondeo.147. donde n está comprendido entre 8 y 15.447.483.79E308 Redondeos de números desde -3.685.79E308.648 hasta +2.768 hasta 32.

sean usados todos o no n bytes como máximo Máximo 2 GB Máximo 2 GB smalldatetime Fecha y hora para uso corriente binary(n) varbinary(n) text image Campo binario de longitud fija Campo binario de longitud variable Campo para texto largo de tipo Memo. El nombre de la tabla debe ir después de la palabra TABLE. El lenguaje de definición de datos (DDL) datetime Fecha y hora para fechas históricas Desde 1-enero-1753 hasta 8 bytes 31-diciembre-9999. Campo para guardar imágenes de hasta 2 Gigas Sql_variant table bit Tipo bit 0ó1 Almacena datos de distintos tipos Almacena datos temporales Desde 1 bit mínimo reutilizado a partir del espacio de otra columna hasta 1 byte máximo si la columna fuera única. genera como resultado una nueva tabla. El nombre de los 99 .© Grupo EIDOS 11. Tabla 25 Creación de tablas Una de las principales sentencias de definición de datos es la de creación de una tabla. Su sintaxis es la siguiente: CREATE TABLE tabla (atributo tipo) La ejecución de esta sentencia. en la base de datos en la que estemos conectados. El dato horario se guarda como número de milisegundos desde la medianoche del día en cuestión Desde 1-enero-1900 hasta 4 bytes 06-junio-2079. El dato horario se guarda como número de milisegundos desde la medianoche del día en cuestión Máximo de 255 bytes de longitud Máximo de 255 bytes de longitud Máximo de 2 Gigabytes de longitud Máximo de 2 Gigabytes de longitud n bytes.

Sin embargo. se deberán separar por comas. SELECT * INTO tabla1 FROM tabla2 Código fuente 4 La anterior sentencia. añadir atributos. y el propietario de la tabla. borrarlos. para poder utilizar esta opción. el propietario de la base de datos. true Código fuente 5 Modificación de tablas Entendemos por modificar una tabla. especificando el tipo. ALTER TABLE tabla ADD atrib tipo NULL Código fuente 6 Nótese que el nuevo atributo añadido debe ser de tipo NULL. Otra opción nos permite cargar un número de filas de otra tabla. La sentencia encargada de esto la vemos en el Código fuente 4. Por ejemplo. o cambiar la definición. 100 . La sentencia que permite modificar una tabla es la que muestra el Código fuente 6. es necesario modificar un parámetro de SQL Server. lo que haría sería volcar el contenido de la tabla tabla2 en la tabla tabla1. sp_dboption base_datos. Para ello. ALTER TABLE tabla1 ADD atributo1 varchar(30) NULL Código fuente 7 Sólo pueden modificar las tablas el administrador. deberíamos ejecutar el Código fuente 7. ya que si no se permiten valores nulos. cambiar su estructura. al crearse los campos de la tabla con este valor. se produciría un error. 'select into/bulkcopy'. es decir. a la tabla tabla1. si queremos añadir un atributo atributo1 de tipo varchar(30).Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS atributos deberá ir entre paréntesis. Si existe más de un atributo. deberemos ejecutar el Código fuente 5. cargando su estructura.

ALTER TABLE tabla ADD CONSTRAINT K1 PRIMARY KEY (cod1. aunque la base de datos esté cargada. De este modo se evitan posibles colisiones que pueden surgir al crear índices cuando la tabla ya tiene datos. esto es no puede admitir duplicados. CREATE UNIQUE INDEX codigo ON todos (cod) WITH IGNORE_DUP_KEY Código fuente 11 101 . Sin embargo. por el campo cod_cliente. El lenguaje de definición de datos (DDL) Borrado de tablas La sentencia que borra una tabla aparece en el Código fuente 8. CREATE INDEX codigo ON todos (cod_cliente) Código fuente 10 Sí además queremos que el índice no admita valores nulos. o el propietario de la misma.© Grupo EIDOS 11. se debe realizar junto con la creación de la estructura de las tablas. Para poder borrar una tabla. debe ir a continuación de la palabra reservada TABLE. Por ejemplo. si creamos un índice único por un campo. Además sólo podrá borrar una tabla el administrador. Creación y borrado de índices La creación de índices en SQL Server. DROP TABLE tabla Código fuente 8 El nombre de la tabla que se borra. se debe ejecutar el Código fuente 11. denominado Código. Para crear un índice en la tabla todos. la generación del índice daría un error. En este caso deberemos hacer un SELECT de otra tabla para liberarla. y se encuentran valores no únicos. SQL Server permite la creación de índices. ésta no debe estar siendo usada. así como en la mayoría de los SGBDR existentes. por los campos cod1 y cod2. cod2) Código fuente 9 Esta sentencia permite añadir una clave primaria en tabla. se debe especificar el Código fuente 10.

se muestra en el Código fuente 12. Esta sentencia se encarga de borrar el índice código creado anteriormente. DROP INDEX codigo Código fuente 12 102 .Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS La sentencia que se encarga de borrar un índice.

Ejemplos prácticos de uso del DDL Introducción Se verán en este capítulo una serie de ejemplos para poner en práctica los conceptos aprendidos en el anterior. plasmado en el analizador de consultas de SQL-Server 2000. para afianzar al lector en el uso del lenguaje de definición de datos. CREATE TABLE tabla (atributo tipo) Código fuente 13 Por ejemplo. La sentencia CREATE TABLE Esta sentencia es la que permite la creación de nuevas tablas dentro de una base de datos. Recordamos su sintaxis en el Código fuente 13. si se encuentra en venta o alquiler y el precio del mismo. se procederá a continuación a crear una tabla destinada a contener información acerca de las ofertas disponibles en una agencia inmobiliaria. la provincia y el domicilio donde se encuentra. la definición de estos esquemas nos servirá como base para utilizar el lenguaje de manipulación de datos en próximos capítulos. La sentencia SQL que nos permite crear esta tabla se muestra en el Código fuente 14: . Interesará almacenar por cada una de las ofertas la siguiente información: un código de identificación. Además. el tipo de bien inmueble al que pertenece.

[Oferta] ( 104 .[ComunidadAutonoma] ( [CA_ID] [int] NOT NULL PRIMARY KEY. Para ello primero borramos el esquema creado anteriormente. y el Código fuente 15 las sentencias a ejecutar para conseguirlo. no podremos crear un tipo de bien inmueble nuevo hasta que no dispongamos de un bien con esas características. El diagrama de la Figura 74 mostraría el esquema resultante. [CA_Nombre] [varchar] (50) NOT NULL ) ON [PRIMARY] GO CREATE TABLE [dbo]. [OF_Provincia] [varchar] (50) NOT NULL .Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS CREATE TABLE [dbo]. Figura 74 DROP TABLE Oferta GO CREATE TABLE [dbo]. [OF_Transaccion] [varchar] (50) NOT NULL .[Oferta] ( [OF_ID] [int] NOT NULL PRIMARY KEY . por ejemplo. [OF_Precio] [int] NOT NULL ) ON [PRIMARY] Código fuente 14 Sin embargo. utilizando la sentencia drop table (aprenderemos como modificar un esquema en el siguiente epígrafe). ya que no esta normalizada. la tabla que hemos creado más arriba puede dar problemas. [OF_Tipo] [varchar] (50) NOT NULL . Por lo tanto procederemos a crear una tabla para los tipos de bienes y otra para las provincias (que a su vez se relacionará con una tabla de comunidades autónomas). [OF_Direccion] [varchar] (50) NOT NULL .

[Com_Apellidos] [varchar] (50) NOT NULL . [OF_Precio] [int] NOT NULL ) GO CREATE TABLE [dbo]. la siguiente información: NIF (que de momento hará las veces de clave primaria de la tabla). dirección.[TipoBien] ( [TB_ID] [int] NOT NULL PRIMARY KEY. necesitando almacenar.[Comercial] ( [Com_NIF] [char] (10) NOT NULL PRIMARY KEY. [Prv_Nombre] [varchar] (50) NOT NULL ) ON [PRIMARY] GO CREATE TABLE [dbo].[Provincia] ( [Prv_ID] [int] NOT NULL PRIMARY KEY. para cada uno de ellos. [Cli_CCC] [varchar] (30) NOT NULL 105 . [TB_ID] [int] NOT NULL . como muestra el Código fuente 17. [Cli_Nombre] [varchar] (50) NOT NULL . [Prv_ID] [int] NOT NULL . [Cli_Telefono] [char] (9) NOT NULL . nombre y apellidos. [Cli_Apellidos] [varchar] (50) NOT NULL . teléfono y sus datos bancarios (nos bastará con el CCC de la cuenta bancaria). [Prv_ID] [int] NOT NULL . se necesitará también conocer los datos personales de los clientes que están suscritos a nuestra agencia. [Com_Telefono] [char] (9) NOT NULL . código postal. [Prv_ID] [int] NOT NULL . [TB_Nombre] [varchar] (50) NOT NULL ) ON [PRIMARY] GO Código fuente 15 Supongamos ahora que se desea tener constancia de los datos personales de los comerciales que trabajan en dicha agencia. provincia. Ejemplos prácticos de uso del DLL [OF_ID] [int] NOT NULL PRIMARY KEY. [Com_Direccion] [varchar] (50) NOT NULL . [Com_Nombre] [varchar] (50) NOT NULL . provincia. como muestra el Código fuente 16 . [OF_Transaccion] [varchar] (50) NOT NULL .© Grupo EIDOS 12.[Cliente] ( [Cli_NIF] [char] (10) NOT NULL PRIMARY KEY. [OF_Direccion] [varchar] (50) NOT NULL . CREATE TABLE [dbo]. siendo en NIF la clave primaria de la tabla. CREATE TABLE [dbo]. [Cli_CodPostal] [char] (5) NOT NULL . teléfono y categoría. dirección. conociendo por cada uno de ellos su NIF. nombre y apellidos. [Cli_Direccion] [varchar] (50) NOT NULL . [CA_ID] [int] NOT NULL . [Com_CodPostal] [char] (5) NOT NULL . código postal. [Com_Categoria] [varchar] (10) NOT NULL ) ON [PRIMARY] GO Código fuente 16 Al igual que para los comerciales.

como muestra el diagrama de la Figura 76 y el Código fuente 18. Nos podemos plantear esta información como dos tablas: una de tipos de transporte (por ejemplo metro y cercanías RENFE) y otra de transportes en sí. Código fuente 18 106 . el diagrama de la Figura 75 muestra la situación actual en la que se encuentra nuestro esquema relacional: Figura 75 Sin embargo. podemos darnos cuenta de que falta una cosa bastante importante para ubicar el inmueble. que almacenará las estaciones o paradas para cada tipo de los mencionados (por ejemplo Legazpi y Pacífico para metro y Fanjul y Móstoles para cercanías).Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS ) ON [PRIMARY] GO Código fuente 17 Hasta el momento. NULL ) KEY.[Transporte] ( [Tr_ID] [int] NOT NULL PRIMARY [Tr_Nombre] [varchar] (30) NOT [TT_ID] [int] NOT NULL ) ON [PRIMARY] GO KEY. y que son los transportes públicos más cercanos de los cuales dispone. NULL.[TipoTransporte] ( [TT_ID] [int] NOT NULL PRIMARY [TT_Nombre] [varchar] (30) NOT ON [PRIMARY] GO CREATE TABLE [dbo]. CREATE TABLE [dbo].

esta sentencia permite la modificación del esquema o la estructura de una tabla ya creada. como nos indica el Código fuente 19 CREATE TABLE [dbo]. así que daremos también de alta esta tabla.© Grupo EIDOS 12. Su sintaxis es la descrita en el Código fuente 20: ALTER TABLE tabla ADD atrib tipo NULL Código fuente 20 107 .[CodigosPostales] ( [Prv_ID] [int] NOT NULL. es una relación 1-N. Ejemplos prácticos de uso del DLL Figura 76 En un momento dado nos puede interesar la posibilidad de tener almacenados en la base de datos todos los códigos postales. [CP_Codigo] [char] (5) NOT NULL PRIMARY KEY ) ON [PRIMARY] GO Código fuente 19 La sentencia ALTER TABLE Como ya se explicó. e importa la clave de esta última tabla). necesitando los siguientes atributos: el código postal (que actuará como clave primaria de la tabla) y la provincia (ya que una misma provincia dispondrá de distintos códigos postales. para posibles clasificaciones de inmuebles o futuras estadísticas.

Esto puede ser muy útil a la hora de calcular comisiones o prever promociones. a no ser que sólo nos interesen dichos datos a título informativo.[Oferta] ADD [Com_NIF] [char] (10) GO Código fuente 21 108 . con objeto de añadir este nuevo atributo a la tabla de ofertas existente como muestra el Código fuente 21. podremos conseguir información de valor añadido si conectamos la tabla de ofertas a la de comerciales. etc. la relación entre tablas. y que se podrían mejorar. Para conseguir esta característica adicional en nuestro esquema. Figura 77 Sin embargo esto nos obliga a modificar el esquema.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Volviendo sobre el ejemplo de la agencia desarrollado en el anterior epígrafe. para de este modo conocer qué comerciales han intervenido en la compra/alquiler de qué inmuebles. Esto es así debido a la relación 1-N que existe entre ambas tablas (un comercial interviene en la transacción de muchos inmuebles. Así. por lo que no mucho sentido. los comerciales aparecen desconectados de las ofertas de bienes. será necesario añadir un atributo más a la tabla de ofertas que la relacione con el comercial. por ejemplo. ALTER TABLE [dbo]. podemos darnos cuenta de varios aspectos del esquema que no son del todo correctos. pero un inmueble sólo puede ser gestionado por un comercial). puesto que el modelo relacional es eso. Pero ya que tenemos esa tabla y. lo que hace que se importe el atributo clave de la tabla de comerciales como muestra el diagrama de la Figura 77.

Si recordamos lo que ocurría con este tipo de relaciones. La conexión entre ambas tablas es similar al caso anterior. Y al igual que en el anterior caso también. El caso de la tabla de transportes es algo especial. enviarles facturas.[Oferta] ADD [Cli_NIF] [char] (10) GO ALTER TABLE [dbo]. ALTER TABLE [dbo]. ya que para un mismo inmueble pueden existir más de una estación de metro cercana. haremos lo mismo con la tabla de códigos postales. formada por ambos atributos. así que se deberá ejecutar el Código fuente 25 para modificar el esquema de forma que se añada una restricción en forma de clave primaria a dicha tabla: ALTER TABLE [dbo]. etc. se necesita modificar el esquema de la base de datos.© Grupo EIDOS 12. la sentencia alter table (véase el Código fuente 23).[Oferta] alter column [Cli_NIF] [char] (10) not null GO Código fuente 23 Siguiendo el mismo razonamiento. que modifique el atributo añadido para que no pueda tomar valores nulos (ya que es una clave ajena): ALTER TABLE [dbo]. de un modo similar.[OfertaTransporte] ( [Of_ID] [int] NOT NULL . [Tr_ID] [int] NOT NULL ) ON [PRIMARY] GO Código fuente 24 Sin embargo esta tabla dispone de una clave primaria compuesta.[Oferta] alter column [Com_NIF] [char] (10) not null GO Código fuente 22 Igual que para los comerciales. Ejemplos prácticos de uso del DLL Sin embargo nos encontramos con un problema. nos interesaría saber qué clientes han comprado/alquilado qué inmuebles. para controlar los pagos. así que deberemos ejecutar una segunda sentencia. se creaba una tabla intermedia que importaba las claves de ambas. El Código fuente 24 muestra la forma de hacerlo: CREATE TABLE [dbo]. [Tr_ID] ) ON [PRIMARY] GO Código fuente 25 109 .[OfertaTransporte] WITH NOCHECK ADD CONSTRAINT [PK_OfertaTransporte] PRIMARY KEY NONCLUSTERED ( [Of_ID]. es un claro ejemplo de relación N-M. que a su vez puede estar próxima a otros inmuebles. así que se utilizará. y es que no podemos añadir un nuevo atributo con la propiedad not null.

CONSTRAINT [FK_Oferta_Provincia] FOREIGN KEY ( [Prv_ID] ) REFERENCES [dbo]. CONSTRAINT [FK_Oferta_TipoBien] FOREIGN KEY ( [TB_ID] ) REFERENCES [dbo]. que es el de las claves ajenas y las restricciones.[Transporte] ADD CONSTRAINT [FK_Transporte_TipoTransporte] FOREIGN KEY ( [TT_ID] 110 .Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Sin embargo no debemos olvidarnos de un aspecto muy importante.[ComunidadAutonoma] ( [CA_ID] ) GO ALTER TABLE [dbo].[Provincia] ( [Prv_ID] ).[Oferta] ( [OF_ID] ).[Oferta] ADD CONSTRAINT [FK_Oferta_Cliente] FOREIGN KEY ( [Cli_NIF] ) REFERENCES [dbo].[Comercial] ( [Com_NIF] ). Ejecutando el Código fuente 26 podremos estar seguro de esto: ALTER TABLE [dbo]. Deberemos relacionar todas las tablas de manera que se establezca una relación entre las claves ajenas que unen las relaciones. para no tener problemas de borrar una tupla de una tabla que sea clave ajena en otra relación.[Provincia] ADD CONSTRAINT [FK_Provincia_ComunidadAutonoma] FOREIGN KEY ( [CA_ID] ) REFERENCES [dbo]. o insertar tipos que no estén dados de alta en las tablas maestras que los tipifican. CONSTRAINT [FK_Oferta_Comercial] FOREIGN KEY ( [Com_NIF] ) REFERENCES [dbo]. CONSTRAINT [FK_OfertaTransporte_Transporte] FOREIGN KEY ( [Tr_ID] ) REFERENCES [dbo].[Cliente] ( [Cli_NIF] ).[Transporte] ( [Tr_ID] ) GO ALTER TABLE [dbo].[TipoBien] ( [TB_ID] ) GO ALTER TABLE [dbo].[OfertaTransporte] ADD CONSTRAINT [FK_OfertaTransporte_Oferta] FOREIGN KEY ( [Of_ID] ) REFERENCES [dbo].

Ejemplos prácticos de uso del DLL ) REFERENCES [dbo]. Con todo esto. poniendo el nombre de la tabla donde se encuentra el atributo que es clave ajena. y su sintaxis es la que se muestra en el Código fuente 27: DROP TABLE tabla Código fuente 27 111 . obtenemos el esquema relacional que se muestra en el diagrama de la Figura 78: Figura 78 La sentencia DROP TABLE Permite el borrado de una tabla existente en la base de datos. seguido de las palabras foreign key y a continuación las referencias a los atributos que son clave en sus relaciones.© Grupo EIDOS 12. la forma de introducir claves ajenas en la base de datos es mediante restricciones.[TipoTransporte] ( [TT_ID] ) GO Código fuente 26 Como podemos ver.

de momento. Es más. no recoge este dato como algo necesario. como muestra el Código fuente 28: Drop table CodigosPostales Código fuente 28 La sentencia CREATE INDEX La sintaxis que permite la creación de índices sobre tablas es la especificada en el Código fuente 29: CREATE [UNIQUE] INDEX indice ON tabla (atributos) Código fuente 29 Recordemos cual es el cometido de un índice. Por ejemplo.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Retomando el ejemplo que nos lleva en este capítulo. La siguiente decisión es considerar si crear un único índice con estos dos atributos. como será el caso. podemos observar que la tabla de código postales. 112 . y su sintaxis es la que se muestra en el Código fuente 31. no nos aporta nada. así que procederemos a su borrado. Pues bien. puede llegar a ralentizar las actualizaciones de datos. conviene crearlos por separado de la siguiente forma: CREATE INDEX oferta1 ON Oferta (Of_Transaccion) GO CREATE INDEX oferta2 ON Oferta (Of_Precio) GO Código fuente 30 La sentencia DROP INDEX Permite el borrado de un índice creado para una tabla. Si suponemos que la mayoría de las consultas se realizarán por ambos criterios. puede dificultarnos la gestión de la base de datos. o crear dos por separado. Veamos que índices podemos crear en el ejemplo que nos lleva este capítulo. que no es otro que el de acelerar las consultas que se realizan sobre una base de datos. ya que un índice es una estructura que si bien acelera las consultas. ya que la información que se precisa para un inmueble. convendría crear un único índice con ambos atributos. Sin embargo y. depende de las consultas que se vayan a realizar. podemos intuir que la mayoría de las consultas de dicha tabla involucrarán a los atributos precio y tipo de transacción (alquiler o venta). la mayoría de las consultas se realizaran por precio o por tipo de transacción. podemos adivinar que la tabla crítica para realizar consultas será la de ofertas. Sin embargo. es una decisión del diseñador el establecer los índices oportunos para que el rendimiento de la misma no se vea afectado. por contra.

oferta2 Código fuente 32 La salvedad es que debemos indicar el código del índice de la forma tabla. 113 .© Grupo EIDOS 12. deberíamos ejecutar: drop index Oferta. para evitar ambigüedades.indice. Ejemplos prácticos de uso del DLL DROP INDEX codigo Código fuente 31 Si en nuestro caso deseáramos borrar el índice oferta2 creado anteriormente.

.

como su propio nombre indica. Una vez vista la anterior forma de representación. Se compone de tres partes: . que pertenece al conjunto del Lenguaje de Manipulación de Datos. y que sirve para recuperar registros de una o varias tablas. el de manipulación de datos.El lenguaje de manipulación de datos (DML) Introducción Ya se ha visto en un capítulo anterior el lenguaje de definición de datos (DDL). puede ser omitido. Su sintaxis es la siguiente: SELECT <atributos> FROM <tablas> [WHERE <condicion>] [GROUP BY <atributos>] [HAVING <condición>] [ORDER BY <atributos>] Donde las mayúsculas representan palabras reservadas. de una o varias bases de datos. manejar los datos contenidos en el esquema. que nos permite. vamos a detenernos en la sintaxis de la sentencia Select. y lo encerrado entre corchetes es opcional. Veremos a continuación el otro lenguaje. que es el que permite definir y modificar la estructura de un esquema. La sentencia Select La sentencia Select es una sentencia SQL.

obtenemos todas las filas. Si se especifica más de una tabla. deseamos obtener todos los atributos de dicha tabla. será conveniente denotar los campos de la cláusula SELECT precedidos por el nombre de la tabla donde se encuentra y un punto. se recuperarán todas las filas. Si por el contrario. nos devuelve toda la información almacenada en ella. WHERE <condición>: permite establecer una condición de recuperación de las filas de la/s tabla/s. price FROM titles Código fuente 33 De esta manera. es decir.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS • SELECT <atributos>: permite hacer una proyección de las tablas. ORDER BY <atributos>: permite obtener el resultado de la consulta ordenado por los atributos especificados. seleccionar los campos que deseamos recuperar de la base de datos. SELECT title. HAVING <condición>: establece una condición para los atributos obtenidos como resultado de la aplicación de funciones escalares. Sólo se obtendrán aquellas tuplas que verifiquen dicha condición. de las cuales sólo visualizaremos los valores de los atributos title y price (especificados en la cláusula SELECT). 116 . en la cláusula FROM. En el caso de que se omita esta parte. • • • • • En el caso de que se especifiquen varias tablas. Si por ejemplo. GROUP BY <atributos>: permite establecer una selección de campos cuando se utilizan funciones escalares o de conteo (ya se verá más adelante lo que significa. Si se especifica el símbolo *. en el caso de que dicho campo exista en más de una tabla. FROM <tablas>: permite especificar la tabla de la cual se desean obtener los datos. separados por comas. SELECT * FROM titles Código fuente 34 Puesto que hemos especificado el literal * dentro de la cláusula SELECT. para que. ya que no hemos dado ninguna condición. deberíamos escribir el Código fuente 34. evitando en este caso el problema de ambigüedad. la anterior sentencia nos devuelve todos los atributos de todas las filas de la tabla titles. es decir. deberíamos escribir el Código fuente 33. éstas irán separadas por comas. que será opcional. deseamos obtener todos los valores de los atributos title y price de la tabla titles. se sepa en cada momento a cual de ellos nos estamos refiriendo. de la tabla titles (especificada en la cláusula FROM). se obtendrán todos los campos de la tabla.

SELECT * FROM titleauthor WHERE royaltyper > 10 Código fuente 35 SELECT * FROM titles WHERE price <= 2 Código fuente 36 Si queremos obtener el nombre de los autores cuya primera letra este comprendida entre la C y la H. es mediante la opción WHERE. SELECT au_fname FROM authors WHERE au_fname LIKE '[C-H]urry' Código fuente 37 117 . aunque también se pueden utilizar operadores de cadena. seleccionando las filas). De la misma forma. El lenguaje de manipulación de datos (DML) La cláusula Where La forma de usar el Transact SQL para realizar consultas realizando una proyección horizontal (es decir. y que a continuación tenga el literal 'urry'. Estos operadores serán vistos en detalle en el siguiente capítulo. si queremos obtener todos los títulos cuyo precio no supere los 2$. ejecutamos el Código fuente 37. A continuación de esta palabra reservada. Para expresar una expresión lógica se pueden emplear cualquiera de los operadores de Transact SQL cuyo resultado devuelva un valor lógico. si queremos obtener los títulos cuyos derechos de autor sean mayores del 10 %. para obtener aquellas filas que la cumplen. se debe especificar la condición lógica que se debe evaluar.© Grupo EIDOS 13. pero básicamente son los siguientes: • • • • • • • • • : compara si una expresión es mayor que otra < : compara si una expresión es menor que otra >= : compara si una expresión es mayor o igual que otra <= : compara si una expresión es menor o igual que otra <>: compara si una expresión es distinta que otra LIKE : compara todas las cadenas que verifican un patrón de búsqueda NOT LIKE : compara todas las cadenas que no verifican un patrón de búsqueda BETWEEN : compara todas las cadenas que están comprendidas en un rango de valores IN : compara todas las cadenas que están contenidas en una lista Por ejemplo. ejecutaremos el Código fuente 36. teclearemos el Código fuente 35.

lo que se hace es simplemente un select. ejecutaremos el Código fuente 39. se resume en una sentencia. pero no de las filas de la tabla. Ringer. en grupos distintos. garantizando así que todas las filas cuyo valor de este atributo sea igual. SELECT title FROM titles WHERE price BETWEEN 1 AND 2 Código fuente 39 La cláusula Group by La cláusula GROUP BY agrupa. filas que tienen el mismo valor para un atributo. Por lo tanto. SELECT city FROM authors WHERE city in ('San Francisco'. cuyo apellido es el mismo. Esto que parece tan complicado. una por cada autor que se apellida Ringer. en lugar de las filas. SELECT au_lname FROM autors Código fuente 40 Si nos fijamos en el resultado obtenido. y a continuación mostrar los grupos. Por ejemplo. SELECT au_lname FROM authors GROUP BY au_lname Código fuente 41 En ella. ejecutaremos el Código fuente 38. Puesto que deseamos agrupar por el apellido. ya que sólo mostramos una fila del grupo. detrás de esta cláusula se debe determinar el atributo au_lname. Con esto garantizamos que sólo se mostrará una fila por cada apellido distinto. tenemos que existen dos autores. que lo único que nos interesa es obtener todos los apellidos que sean distintos. 118 . irán al mismo grupo. en lugar de todas. usando la cláusula GROUP BY. ejecutamos el Código fuente 40. que se corresponda con San Francisco o con Salt Lake City. se muestran dos filas iguales para este apellido.'Salt Lake City') Código fuente 38 Si se desea conocer todos los títulos cuyo precio oscila entre 1 y 2 dólares. Para ello deberemos agrupar los autores cuyo apellido sea el mismo en un único grupo. sino de los grupos obtenidos a partir de la cláusula GROUP BY.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS O si queremos obtener la ciudad de todos los autores. como su propio nombre indica. Supongamos ahora. si queremos obtener el apellido de todos los autores.

Las funciones que soporta la sentencia SELECT en el Transact SQL son las siguientes: • SUM: Realiza una suma acumulativa de un atributo para todas las filas accedidas mediante una consulta SQL. SELECT au_lname FROM authors GROUP BY au_lname HAVING au_lname = 'Ringer' Código fuente 42 La cláusula Order by La cláusula ORDER BY determina el orden de visualización de las filas obtenidas en la sentencia SELECT. con los atributos cod_cliente. etc. deseamos que sólo se muestre el autor cuyo apellido sea Ringer. Dichas funciones se especifican a continuación de la palabra reservada SELECT. obtención de medias. cod_material y precio. en este caso alfabéticamente por el apellido. Por ejemplo. todas aquellas que permiten realizar operaciones de conteo de filas. A continuación de dicha palabra reservada. Si queremos obtener la suma del precio de todos los pedidos almacenados. es decir. Por ejemplo. se debe especificar el atributo o los atributos por los cuales se ordenará el resultado obtenido en la consulta. como la que vemos en el Código fuente 44. SELECT sum(precio) FROM pedido Código fuente 44 119 . si dada la anterior sentencia de agrupación. Por ejemplo. si queremos mostrar el nombre y apellido de todos los autores de nuestra base de datos pubs. suma de atributos. au_lname.© Grupo EIDOS 13. Por lo tanto el funcionamiento es similar al ya visto para WHERE. bastará con realizar una función de tipo SUM. El lenguaje de manipulación de datos (DML) La cláusula Having La cláusula HAVING es similar a la cláusula WHERE. supongamos que tenemos una tabla de pedidos. determina cómo se ordenarán las filas que se mostrarán. La única diferencia es que HAVING se aplica a condiciones de grupo. bastará con ejecutar la sentencia que aparece en el Código fuente 43 donde el atributo especificado a continuación de la cláusula ORDER BY. salvo que aquella se usa como condición de búsqueda cuando se especifica la cláusula GROUP BY. ejecutaremos el Código fuente 42. au_fname FROM authors ORDER BY au_lname Código fuente 43 Funciones escalares para Select Entendemos por funciones escalares. SELECT au_lname.

Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS La anterior consulta obtiene la suma del precio para todas las filas de la tabla pedido. SELECT count(*) FROM cliente Código fuente 47 Si ahora queremos saber el número de clientes que viven en Madrid. Por ejemplo. se suele escribir el Código fuente 47. dirección y población. y queremos saber todos los clientes que tenemos. SELECT count(*) FROM cliente WHERE poblacion = "Madrid" Código fuente 48 Si queremos saber cuantos títulos tenemos nuestra base de datos. sea cual sea el atributo que seleccionemos. con los atributos DNI. deberemos realizar un conteo de todas las filas con la condición de que el atributo población sea Madrid. SELECT count(DNI) FROM cliente Código fuente 46 En el anterior ejemplo. podríamos haber escogido cualquier otro. nombre. Si ahora queremos obtener la suma total de todos los pedidos realizados por el cliente cuyo código es "R12CE". pero especificando una condición para obtener únicamente las filas cuyo cod_cliente es "R12CE": SELECT sum(precio) FROM pedido WHERE cod_cliente = "R12CE" Código fuente 45 • COUNT: Cuenta todas las filas de las tablas accedidas mediante una consulta SQL. para obtener todas el número de filas de la tabla ejecutamos el Código fuente 46. con todos los clientes de una empresa de servicios. si tenemos una tabla cliente. ya que no hemos especificado ninguna condición en la cláusula WHERE. apellidos. En general. al existir el mismo número de filas. teclearemos el Código fuente 49. debemos realizar la misma consulta. deberemos realizar un count. SELECT count(*) FROM titles Código fuente 49 120 .

SELECT count(*) caros FROM titles WHERE price > 20 Código fuente 50 • AVG: Realiza una media aritmética de los atributos para todas las filas accedidas mediante la consulta SQL. Volviendo a nuestra cultural base de datos pubs. es decir. que tenemos la tabla de materiales descrita anteriormente. con los atributos cod_material. internamente. Al resultado de la búsqueda le llamaremos caros. realiza primero una suma de todos los valores. El lenguaje de manipulación de datos (DML) Y si queremos saber cuantos títulos tenemos. deberemos realizar una media aritmética. Para nuestro ejemplo. Supóngase. deberemos ejecutar el Código fuente 52. ejecutaremos el Código fuente 53. de entre todas las filas seleccionadas mediante la sentencia SQL. y queremos saber la cantidad media pedida de todos los materiales. deberemos realizar lo mismo. deberemos realizar un SELECT con la cláusula max. cuyo precio es mayor de 20 $. SELECT avg(price) media FROM titles Código fuente 52 • MAX: Obtiene el máximo valor del atributo especificado. Si por ejemplo tenemos una tabla de materiales. precio y cantidad_pedida. si queremos saber cual es el libro más caro. que obtenga el mayor valor para el atributo precio de todas las filas. pero especificando esta condición en la cláusula WHERE. realiza la media aritmética. teniendo en cuenta todas las filas de la tabla: SELECT avg(cantidad_pedida) FROM material Código fuente 51 La anterior sentencia.© Grupo EIDOS 13. Si queremos saber el material mas caro. y a continuación la divide por el número total de filas accedidas. si queremos saber la media del precio de los títulos que tenemos disponibles. descripción. SELECT max(price) caro FROM titles Código fuente 53 121 . por ejemplo.

authors'. Si SELECT nos permitía recuperar datos. 'Perez'. si ejecutamos la anterior sentencia. atributos es una lista de atributos separados por comas que determinan los atributos para los cuales se darán valores. mientras que si es numérico no. Line 1 Cannot insert the value NULL into column 'contract'. INSERT nos va a permitir añadirlos al esquema. SELECT min(price) barato FROM titles Código fuente 54 La sentencia Insert La otra gran sentencia de manipulación de datos es INSERT. Si queremos saber cual es el libro más barato de nuestra base de datos. au_fname. Si sólo queremos insertar un valor para un atributo.dbo. Sin embargo. deberemos ejecutar el Código fuente 55. el resto de los de la tabla deberá contener el valor nulo (NULL). INSERT fails. Recordemos que estamos en el modelo relacional. con esta sentencia podemos añadir información a la base de datos. Level 16. obtenemos el siguiente error: Server: Msg 515. por lo que la información se añadirá a una tabla en forma de filas. Por lo tanto. en cuyo caso deberemos especificar un valor para éste. que ha sido definido como no nulo. separados por comas. para dar un valor al Código fuente 56. La sintaxis de este sentencia es: INSERT INTO tabla (atributos) VALUES (valores) donde tabla especifica la tabla en la cual se añadirá la fila. rectificamos el Código fuente 55. cuando el atributo esté definido como NO NULO. contract) VALUES ('409-99-9876'. 1) Código fuente 56 122 . 'Pepe'. deberá ir encerrado entre comillas. INSERT INTO authors (au_id. column does not allow nulls. The statement has been terminated. INSERT INTO authors (au_id. si queremos añadir un nuevo autor a nuestra base de datos. Por ejemplo. habrá ciertas ocasiones en que esto no será posible.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS • MIN: Obtiene el mínimo valor del atributo especificado. de entre todas las filas seleccionadas mediante la sentencia SQL. au_lname. 'Pepe'. au_lname. y valores especifica los valores que se darán para estos atributos. table 'pubs. State 2. au_fname) VALUES ('409-99-9876'. Pues bien. La razón es que no hemos dado valor al atributo contract. es decir. 'Perez') Código fuente 55 Destacar que si el valor a introducir es alfanumérico. deberemos ejecutar el Código fuente 54.

© Grupo EIDOS 13. y lo que viene a continuación de SET especifica la asignación de los nuevos valores a los atributos. Podemos comprobarlo ejecutando un SELECT sobre dicha fila. por el código (condición where). . 0 para especificar que no está contratado. SELECT * FROM authors WHERE au_id = '409-99-9876' Código fuente 57 La sentencia Update El objetivo de la sentencia UPDATE es actualizar los valores de una o varias filas de una tabla.. Si queremos cambiar el nombre al autor que hemos insertado en el anterior apartado. Por lo tanto se actualizarán todas las filas que cumplan la condición especificada. Para poder borrar filas en una tabla se deben cumplir las condiciones de seguridad determinadas por el administrador (se verán en un 123 . y 1 para el caso contrario. WHERE condicion donde tabla especifica la tabla donde se encuentran las filas que queremos actualizar. atributo2 = valor2. obtenemos el resultado: (1 row(s) affected) lo que quiere decir que la fila ha sido actualizada con éxito. SELECT * FROM authors WHERE au_id = '409-99-9876' Código fuente 59 La sentencia Delete El objeto de la sentencia DELETE es el de borrar filas de una tabla. sin necesidad de borrarla e insertarla de nuevo. UPDATE authors SET au_fname = 'Pepito' WHERE au_id = '409-99-9876' Código fuente 58 Lo que hacemos con la anterior sentencia es buscar el autor insertado. sólo admite dos valores. deberemos escribir el Código fuente 58. condición especifica la condición que se debe cumplir para actualizar las filas. y a continuación actualizar el valor del atributo nombre de la fila obtenida a Pepito. es decir. ya que está definido como tipo binario.. Al ejecutar esta sentencia. La sintaxis es la siguiente: UPDATE tabla SET atributo1 = valor1 . El lenguaje de manipulación de datos (DML) El valor que hemos dado al atributo contract es un 1. Si ejecutamos la anterior sentencia. obtenemos como resultado (1 row(s) affected) lo que nos indica que la fila se ha insertado con éxito. Podemos comprobarlo ejecutando el Código fuente 59.

La sintaxis es la siguiente: DELETE FROM tabla WHERE condicion donde tabla especifica la tabla sobre la cual queremos borrar las filas. es decir. SELECT * FROM authors WHERE au_id = '409-99-9876' Código fuente 62 124 . ejecutamos la sentencia que muestra el Código fuente 62. la sentencia que aparece en el Código fuente 60 borra todas las filas de la tabla authors. Si omitimos la condición. si queremos borrar la fila que hemos creado en la tabla autores. lo que quiere decir que la fila no se encuentra en la tabla. se borrarán todas las filas de la tabla. deberemos ejecutar el Código fuente 61. Para comprobarlo. y condición especifica la condición que se debe cumplir para que se borren las filas. obteniendo el siguiente resultado: (1 row(s) affected) DELETE FROM authors WHERE au_id = '409-99-9876' Código fuente 61 lo que viene a decir que la fila se ha borrado.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS próximo capítulo). DELETE authors Código fuente 60 Por ejemplo. ha sido borrada. y deben de cumplirse también las reglas de integridad referencial. cuyo resultado es: (0 row(s) affected). es decir.

Las principales que veremos aquí son: • • • Proyección Unión Join o combinación No confundir los anteriores operadores propios del álgebra relacional. Dicho operador consiste en restringir la cantidad de información que obtenemos de una o varias tablas. es decir. así como algunas apreciaciones acerca del lenguaje que ofrece Transact SQL. sobre todo para acotar la consulta de tablas.Operadores básicos y consideraciones del lenguaje Introducción En este capítulo se describirán con detalle los operadores básicos. Entendemos por operadores. Operador proyección El operador de proyección es muy usado. con los que ofrece SQL Server. . etc. comparaciones lógicas. unión de cadenas. aquellas palabras reservadas o símbolos delimitadores que nos permiten aplicar las diversas técnicas del álgebra relacional. los que permiten la evaluación de expresiones.

aunque también se puede acotar el resultado de ésta. A este nombre se le denomina alias y sirve para que el atributo obtenido aparezca con otro nombre. en nuestro ejemplo. Así. nos conectamos a la base de datos pubs. seguido por un punto. SELECT tabla1. campo2 FROM tabla1 Código fuente 63 El método no varia si queremos realizar la proyección sobre más de una tabla.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Aquí veremos la proyección vertical. dichos atributos aparecen bajo los nombre título y tipo. especificando una condición. seleccionándola en la lista desplegable de la parte superior derecha.campo1. se precede el nombre de la tabla al del campo. y separados por comas. 126 . tabla2. Para especificar los atributos de la tabla o tablas que deseamos que aparezcan en la consulta. tabla2 Código fuente 64 En el anterior ejemplo se ha proyectado sobre dos campos de dos tablas distintas. para que el resultado se aplique únicamente a las tuplas que la cumplan. Para especificar las tablas sobre las cuales se desea realizar la proyección. se recuperarán todas las filas de la tabla titles. Veamos ahora como realizar una proyección utilizando Transact SQL. del campo1 de tabla2. se deberán especificar después de la palabra reservada FROM. que son los alias que les hemos dado respectivamente. es decir. Así. Una vez abierto. y tecleamos el Código fuente 65. y realizaremos una proyección sobre los atributos title y type. se deberán proporcionar éstos a continuación de la palabra reservada SELECT. SELECT title título. Para distinguir el campo1 de tabla1. pero como podemos observar en el resultado mostrado en la Figura 79. type tipo FROM titles Código fuente 65 Nótese como después de cada atributo hemos tecleado otro nombre.campo1 FROM tabla1. Probemos ahora con el query analyzer. el Código fuente 63 realiza una proyección de los atributos campo1 y campo2 de la tabla tabla1: SELECT campo1. en realizar una criba sobre aquellos atributos que nos interesen para todas las filas de una tabla.

si queremos obtener la unión de las dos consultas a dos tablas. El Código fuente 66 constituye un ejemplo de unión de las tablas tabla1 y tabla2: SELECT * FROM tabla1. para obtener el resultado consultando en varias tablas. escribiremos el Código fuente 67. que no es ni más ni menos. Pulsamos ahora el botón de ejecución. El resultado obtenido contendrá entonces campos de las tablas especificadas en la cláusula FROM. y quedarnos luego sólo con la información relevante. es utilizar la palabra reservada UNION. que todas las filas de las tablas titles y titleauthor. y obtenemos el resultado mostrado en la Figura 80. Por ejemplo. sino junto con el de proyección. Este operador casi nunca se utiliza por separado.© Grupo EIDOS 14. 127 . como su propio nombre indica. o F5. en unir campos de más de una tabla. tecleando el Código fuente 68. tabla2 Código fuente 66 Otra forma de realizar una unión entre el resultado de dos consultas. Probemos ahora en el query analizer. Operadores básicos y consideraciones del lenguaje Figura 79 Operador Union El operador unión consiste.

tabla2 WHERE tabla1. cuyos atributos comunes coincidan.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Figura 80 SELECT * FROM tabla1 UNION SELECT * FROM tabla2 Código fuente 67 SELECT * FROM titles. Sirve para combinar dos tablas entre sí. titleauthor Código fuente 68 Operador join El operador de join es uno de los más usados en el álgebra relacional. utilizando un atributo común. La forma de realizarlo en Transact SQL es especificando en la cláusula WHERE los atributos por los cuales se va a realizar el join entre ambas tablas. SELECT * FROM tabla1. Lo que se realiza es una unión de cada fila de una tabla.campo1 Código fuente 69 128 . con todas las filas de la tabla con la que se hace el join.campo1 = tabla2.

Dentro de este tipo de join. no existe en el atributo campo1 de la tabla 2. Supóngase que tenemos las dos siguientes tablas. existen dos categorías: 129 . Operadores básicos y consideraciones del lenguaje El Código fuente 69 realiza un join entre las tablas tabla1 y tabla2. El join de estas dos tablas queda como muestra la Tabla 28 tabla1. Por ejemplo. Veamos un ejemplo de como funciona un join. hay dos filas en la Tabla 27 cuyo atributo campo1 es igual. la tercera fila de la tabla 1. pero incluyendo todas las filas de ambas tablas. A este tipo de join se le denomina inner join. consiste en realizar el join. copiando cada fila de la primera tabla. y para cada fila cuyo campo común sea igual en ambas tablas.campo1 1 1 2 tabla2. copiar las filas de la segunda tabla. no aparece en el join. y deseamos hacer un join por el atributo campo1 de ambas.campo2 5 3 8 Como hemos podido comprobar.© Grupo EIDOS 14. Esto es debido a que el valor del atributo por el que se hace el join (campo1). para la primera fila de la Tabla 26. denominado outer join. por el campo1 de ambas tablas. cuyo valor es 3. aunque éstas no tengan correspondencia en su homóloga. Campo1 1 2 3 4 Tabla 26 Campo2 10 9 4 1 Campo1 1 1 2 Campo2 5 3 8 Tabla 27 Lo primero que se realiza al hacer un join es una unión de ambas tablas. El otro tipo de join.campo1 1 1 2 Tabla 28 tabla2.campo2 10 10 9 tabla1.

la sentencia para realizar este rigth join aparece en el Código fuente 71. Tabla1.campo2 Código fuente 71 También se puede realizar un join por más de un campo. 130 . aunque éstas no tengan correspondencia en la segunda.campo1 1 1 2 ? Tabla 30 tabla2.campo1 1 1 2 3 Tabla 29 tabla2.campo = tabla2.campo2 10 10 9 4 tabla1.campo2 5 3 8 1 En Trasact SQL. El Código fuente 72 realiza un join entre las tablas Tabla 26 y Tabla 27. tabla1. Los campos de la segunda tabla se rellenan con interrogantes. por los campos comunes campo1 y campo2.campo1 1 1 2 ? tabla2. SELECT * FROM tabla1 left join tabla2 on tabla1. aunque éstas no tengan correspondencia en la primera. Los campos de la primera tabla se rellenan con interrogantes.campo2 Código fuente 70 • Rigth join: incluyen todas las filas de la segunda tabla. la sentencia para realizar este left join se muestra en el Código fuente 70.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS • Left join: incluyen todas las filas de la primera tabla.campo2 5 3 8 ? En Trasact SQL.campo2 10 10 9 ? tabla1.campo1 1 1 2 4 tabla2. SELECT * FROM tabla1 rigth join tabla2 on tabla1.campo = tabla2.

campo2 Código fuente 72 En el lenguaje de manipulación de datos. Si se desea obtener el título de cada obra.title_id = titleauthor. En la cláusula WHERE. A continuación. authors. deberemos ejecutar el Código fuente 73. se genera una tabla intermedia con la clave de cada tabla).au_id = authors. que es la que almacena el código de cada título. titles. podemos acceder a los autores. Por lo tanto. además de las condiciones de join. precisamente por el campo au_id. A partir de esta tabla.au_id Código fuente 73 Analicemos la anterior sentencia. Deberemos acceder a la tabla de títulos. Veamos un ejemplo de implementación de join en Transact SQL.title. authors. authors WHERE titles. Como se puede observar.title. junto con sus autores. pero añadiendo ahora una nueva condición. authors WHERE titles. que es donde se encuentra el título de cada obra. Operadores básicos y consideraciones del lenguaje SELECT * FROM tabla1. aunque de éstas no se muestre ningún atributo. en la cláusula FROM se deben especificar todas las tablas que serán accedidas. una de las operaciones más usuales es precisamente la de join de varias tablas.au_lname.price FROM titles. si queremos obtener una relación de todos los títulos cuyo precio no supere los 20 $. realizando un join de la tabla titleauthor con la tabla authors.© Grupo EIDOS 14.au_lname FROM titles.campo1 AND tabla1. junto con los autores que lo han escrito (recuérdese que en las relaciones N-M.campo2 = tabla2.au_id AND titles.title_id AND titleauthor. ejecutaremos la misma sentencia que antes. El resultado es el mostrado en la Figura 81. que es el código del autor. con la tabla intermedia titleauthor. la cláusula WHERE realiza los dos join necesarios para acceder a las tres tablas. que es que el atributo price de la tabla titles no supere los 20$. junto con el nombre de su autor.au_id = authors. SELECT titles.title_id AND titleauthor. podremos especificar otro tipo de condiciones. tabla2 WHERE tabla1.title_id = titleauthor. Por ejemplo. realizamos un join de esta tabla.campo1 = tabla2.price < 20 Código fuente 74 131 . titleauthor. titleauthor. SELECT titles.

Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Figura 81 Figura 82 Operadores propios de Transact SQL Los operadores que nos proporciona SQL Server se dividen en varios grupos: 132 .

: suma. DESCRIPCIÓN + Operadores Aritméticos * / % Suma Resta Multiplicación División Módulo o resto de la división entera AND binario (1 si los bits de ambos operandos son 1) EJEMPLO SELECT 2 + 4 SELECT 3 . multiplicación. Ej. etc. Ej.© Grupo EIDOS 14. De nivel de bit: realizan operaciones transformando los operandos a bits.: comparaciones. De cadena: realizan operaciones que afectan a strings o cadenas de caracteres. etc. La Tabla 31 muestra un resumen de los principales operadores con que nos podemos encontrar en Transact SQL.:concatenación. búsqueda. etc. Ej. división. etc.1 SELECT 3 * 2 SELECT 6 / 2 SELECT 4 % 3 RESULTADO 6 2 6 3 1 11 & 10 = 10 >2 11 | 10 = 11 -> 3 11 ^ 10 = 01 -> 1 ~10 = 01 -> 1 & SELECT 3 & 2 | Operadores nivel de bit ^ OR binario (1 si el bit de alguno de los dos SELECT 3 | 2 operandos es 1) OR exclusivo binario (1 si el bit de los SELECT 3 ^ 2 operandos es distinto) NOT binario (cambia el bit) SELECT ~ 2 ~ Operadores lógicos = < > >= <= Igual Menor Mayor Mayor o igual Menor o igual SELECT 1 = 2 SELECT 1 < 2 SELECT 1 > 3 SELECT 1 >= 1 SELECT 10 <= 1 FALSO VERDADERO FALSO VERDADERO FALSO 133 .: AND al nivel de bit. Lógicos: realizan operaciones que devuelven un resultado lógico. Operadores básicos y consideraciones del lenguaje • • • • Aritméticos: realizan operaciones aritméticas. Ej.

si queremos obtener todos los títulos cuyo precio oscile entre los 30 y los 50 dólares.M _ SELECT * FROM tabla WHERE atributo2 like '_urry' Hurry Otros operadores importantes aplicables a expresiones son los siguientes: • BETWEEN: Verifica los valores comprendidos dentro del rango especificado. ejecutamos el Código fuente 76. 134 . NOT: negación de la expresión LIKE: búsqueda por patrón Cadena con ese carácter coincidente. La sintaxis es: expresion IN lista Por ejemplo. escribimos el Código fuente 75.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS <> != !> !< + Distinto Distinto No mayor No menor Concatenación Cadenas coincidentes.L.K. SELECT * FROM titles WHERE price BETWEEN 10 AND 50 Código fuente 75 • IN: Verifica si el valor especificado está contenido dentro de una lista de ellos. La sintaxis es: expresion BETWEEN expresion AND expression Por ejemplo. NOT: negación de la expresión LIKE: búsqueda por patrón Cadenas no coincidentes. NOT: negación de la expresión LIKE: búsqueda por patrón Tabla 31 SELECT 1 <> 2 SELECT 1 != 1 SELECT 1 !> 3 SELECT 1 !<1 SELECT 'A' + 'B' SELECT * FROM tabla WHERE atributo1 LIKE '[CH]urry' SELECT + FROM tabla WHERE atributo1 NOT LIKE '[^I-Z]' VERDADERO FALSO VERDADERO VERDADERO AB [] Curry Hurry Operadores de Cadena [^] J. si queremos obtener el nombre de todos los autores que vivan en San Francisco o en Salt Lake City.

'Salt Lake City') Código fuente 76 También se puede especificar como lista. que viven en ciudades pertenecientes al estado de California (CA). -1: preselección erronea.33 milisegundos) de ocupación de la CPU ejecutando instrucciones SQL Server desde que éste fue ejecutado número de filas seleccionadas en la última selección número del primer día de la semana número del último error producido en la ejecución de una sentencia. y luego se aplica el valor obtenido para la evaluación del operador IN.© Grupo EIDOS 14. La Tabla 32 muestra un resumen con las variables globales que nos pueden resultar de utilidad: @@connections @@cpu_busy @@cursor_rows @@datefirst @@error @@fetch_status @@identity @@idle @@io_busy @@LANGID número de conexiones realizadas desde que se ejecutó SQL Server número de ticks (3. es decir. etc. Variables globales Existe un conjunto de variables globales. -2: filas no disponibles) identificador de la última operación realizada número de ticks de tiempo ocioso de CPU desde que se ejecutó SQL Server número de ticks de tiempo empleado en realizar operaciones de entrada/salida desde que se ejecutó SQL Server lenguaje local actual seleccionado 135 . o del resultado de una consulta. Por ejemplo. primero se evalúa la sentencia que está entre paréntesis. el resultado de otra consulta. la forma de evaluación es desde dentro hacia fuera. que informan en cada momento del estado del sistema. 0 si no ha habido error estado de la preselección (0: preselección satisfactoria. escribimos el Código fuente 77. si queremos obtener el nombre de los autores. Esta variables se pueden distinguir porque comienzan por dos arrobas @@. SELECT au_lname FROM authors where city IN (SELECT city FROM authors WHERE state = 'CA') Código fuente 77 En la anterior consulta. Operadores básicos y consideraciones del lenguaje SELECT au_lname FROM authors where city in ('San Francisco'.

fecha y tipo de procesador actualmente en uso para SQL Server Tabla 32 136 .Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS @@language @@lock_timeout @@max_connectio ns @@max_precision @@nestlevel @@options @@pack_received @@pack_sent @@packet_errors @@procid @@remserver @@rowcount @@servername @@servicename @@spid @@textsize @@timeticks @@total_errors @@total_read @@total_write @@trancount @@version descripción del lenguaje especificado para SQL server tiempo de time-out (tiempo hasta el cual se intenta dar por válida la transacción) en milisegundos para bloqueo número máximo de conexiones simultaneas que permite SQL Server nivel de precisión usado por los tipos de datos decimal y numeric nivel de anidamiento del actual procedimiento almacenado información sobre las opciones de usuario número de paquetes recibidos por SQL Server desde que se inicializó número de paquetes enviados por SQL Server desde que se inicializó número de paquetes erróneos desde que SQL Server se inicializó identificador del actual procedimiento almacenado nombre del servidor remoto número de filas afectadas por una sentencia de selección nombre del servidor local nombre de la clave de registro para SQL Server identificador del proceso actualmente en ejecución tamaño máximo para los tipos de datos texto e imágenes número de milisegundos por tick de CPU número total de errores producidos desde que se inicializó SQL Server número de lecturas de disco desde que se inicializó SQL Server número de escrituras en disco desde que se inicializó SQL Server número de transacciones activas por el usuario en curso versión.

Existen dos tipos de sentencias condicionales. se ejecutará la rama ELSE. se ejecutará la sentencia 2. se devolverá el resultado correspondiente especificado a continuación de la palabra reservada THEN... Operadores básicos y consideraciones del lenguaje Sentencias condicionales Las sentencias condicionales son aquellas que permiten discriminar entre diversas sentencias. Si deseamos obtener los títulos almacenados cuando éstos superen las 10 unidades. si queremos saber el nombre de los estados de los autores. con el resto de expresiones especificadas a continuación de la palabra reservada WHEN. no ha verificado ninguna de las expresiones. se devolverá el resultado especificado a continuación del ELSE. En otro caso. [ELSE resultado3] La anterior sentencia compara la expresión 1. corresponde a la sentencia CASE. SELECT state = CASE state WHEN 'CA' THEN 'California' WHEN 'OR' THEN 'Oregon' ELSE 'Otro' 137 . la sentencia SELECT title FROM titles sólo se ejecuta cuando se cumple la condición (SELECT count(*) FROM titles) > 10. Por ejemplo. La primera de ellas tiene la siguiente sintaxis: IF expresion_logica sentencia1 [ELSE sentencia2] La sentencia 1 sólo se ejecutará si el resultado de la evaluación de la expresión lógica es verdadera. en lugar de una sola. ejecutaremos el Código fuente 78. correspondiente a la parte ELSE (opcional). en lugar de las iniciales. y el número de ellos cuando no lo superen. que devuelve el número de títulos almacenados en la tabla titles. IF (SELECT count(*) FROM titles) > 10 BEGIN SELECT title FROM titles END ELSE BEGIN SELECT count(*) FROM titles END Código fuente 78 En definitiva. La sintaxis es la siguiente: CASE expresion1 WHEN expresion2 THEN resultado1 WHEN expresion3 THEN resultado2 . Si llegados al final. En otro caso. podemos ejecutar el Código fuente 79. Si se desea especificar un conjunto de sentencias. Otra forma de ejecutar sentencias de forma condicional. éstas deberán ir encerradas entre las palabras reservadas BEGIN y END.© Grupo EIDOS 14. Si alguna de estas expresiones se cumple. según se cumpla el valor de una expresión lógica.

y si este es igual a CA. mientras se cumpla una condición lógica. mientras que CONTINUE permite ejecutar de nuevo las sentencias desde el comienzo del bucle. aunque se cumpla la expresión lógica. si es OR se devolverá Oregon. y abandonarlo. y en otro caso se devolverá el literal 'Otro'. y su sintaxis WHILE expresion_logica sentencia [BREAK] [CONTINUE] La sentencia especificada se ejecuta de forma iterativa. La cláusula BREAK. La sentencia que permite realizarlo es WHILE. ignorando aquellas que vienen a continuación del CONTINUE. mientras se cumpla la expresión lógica. 138 . permite romper el bucle.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS END FROM authors Código fuente 79 En este caso se comprueba el valor del atributo state. Sentencias iterativas Una sentencia iterativa es aquella que permite ejecutar una o varias sentencias de manera repetida. se devolverá California.

es decir. los atributos que se van a insertar. y así sucesivamente. al atributo especificado en primer lugar se le asignará el valor indicado en primer lugar. que ya se ha visto. y <valores> es una lista de valores separados por comas. La palabra reservada INTO es opcional y se puede omitir en la sentencia. o si no especificamos un valor concreto para este tipo de columnas. y los valores para dichos atributos.La sentencia INSERT Introducción La sentencia insert permite la introducción de nuevos registros dentro de un esquema. . especifica el nombre de una tabla. Su sintaxis. Sintaxis La sintaxis de la sentencia insert es la siguiente INSERT INTO <tabla> (<atributos>) VALUES (<valores>) donde <atributos> es una lista de atributos separados por comas. Si insertamos un valor nulo para un atributo que no acepta ese tipo de valores. Existe una correspondencia unívoca entre los atributos y los valores. se producirá un error y la fila no será insertada.

CA_Nombre) VALUES (1. ‘Madrid’) Código fuente 80 Figura 83 Para ver si efectivamente se han insertado ambos registros. Insertaremos dos Comunidades Autonomas en la tabla de comunidades.Bases de datos con SQL Server2000 – Transact SQL © Grupo EIDOS Ejemplos Para comenzar veremos un ejemplo sencillo de inserción de tuplas en la tabla del ejemplo de la agencia inmobiliaria que venimos manejando. SELECT * FROM ComunidadAutonoma Código fuente 81 140 . CA_Nombre) VALUES (2. ‘Catalunya’) INSERT INTO ComunidadAutonoma (CA_ID. como indica el Código fuente 80. INSERT INTO ComunidadAutonoma (CA_ID. ejecutamos una sentencia select como muestra el Código fuente 81 (véase la Figura 83).

© Grupo EIDOS

15. La sentencia INSERT

Como decíamos, si ahora intentamos insertar otra provincia si especificar el atributo CA_ID, que es clave, se producirá un error, como podemos observar en la Figura 84 al ejecutar el Código fuente 82.

INSERT INTO ComunidadAutonoma (CA_Nombre) VALUES (‘Andalucía’) Código fuente 82

O si por el contrario introducimos un valor duplicado para la clave, también obtendremos el error de la Figura 85 al ejecutar el Código fuente 83.

INSERT INTO ComunidadAutonoma (CA_ID, CA_Nombre) VALUES (1, ‘Andalucía’) Código fuente 83

Figura 84

Otra forma de introducir filas es no especificando la lista de atributos, en cuyo caso los valores se van asignando de manera secuencial a los atributos de la tabla. Por ejemplo en el Código fuente 84 se asigna el valor 3 al atributo CA_ID y ‘Andalucía’ al atributo CA_Nombre.

141

Bases de datos con SQL Server2000 – Transact SQL

© Grupo EIDOS

Figura 85

INSERT INTO ComunidadAutonoma VALUES (3, 'Andalucía') Código fuente 84

Del mismo modo se pueden especificar valores para los atributos en distinto orden, siempre que se expresen de manera explícita en la lista de los mismos, como muestra el Código fuente 85, en el que se asigna el código 1 a la provincia Madrid, que pertenece a la comunidad de Madrid (es decir, código 2).

INSERT INTO Provincia (Prv_Nombre, Prv_ID, CA_ID) VALUES ('Madrid’, 1, 2) Código fuente 85

Así mismo se pueden especificar menos valores que atributos, siempre que para los atributos que no se especifiquen se puedan insertar valores nulos o los establecidos por defecto. La forma de asignar estos valores por defecto es como se muestra en el Código fuente 86.

INSERT INTO tabla DEFAULT VALUES Código fuente 86

142

© Grupo EIDOS

15. La sentencia INSERT

Esto insertaría una nueva fila en la tabla, con los valores establecidos por defecto. Otra forma de insertar filas es a partir del resultado de una consulta. Por ejemplo, el Código fuente 87 insertaría en la tabla 2, los valores de la tabla 1. Ni que decir tiene que ambos esquemas deben coincidir. También se puede especificar un filtro en la claúsula where para la consulta.

INSERT INTO tabla2 SELECT * FROM tabla1 Código fuente 87

Carga de la base de datos de ejemplo
Para concluir este capítulo, se ofrecen las sentencias necesarias para cargar las tablas de la base de datos del ejemplo de la agencia inmobiliaria que venimos utilizando.

INSERT INTO Provincia VALUES (2, 1, 'Barcelona') INSERT VALUES INSERT VALUES INSERT VALUES INTO TipoBien (1, 'Piso') INTO TipoBien (2, 'Chalet') INTO TipoBien (3, 'Solar')

INSERT INTO Cliente VALUES ('11384H', 'Juan Jose', 'Martinez', 'C/Bernardino 2', '28021', 1, '913382888', '12888271777') INSERT INTO Cliente VALUES ('11383K', 'Alfonso', 'Loira', 'C/Apache 34', '28023', 1, '913334888', '123423471777') INSERT INTO Cliente VALUES ('123454L', 'Amadeo', 'Lerra', 'C/Portugal 4', '08021', 2, '933485888', '1282344777') INSERT INTO Comercial VALUES ('113384H', 'Juan Alberto', 'Espado', 'C/Alcala 321', '28038', 1, '914538288', '1') INSERT INTO Comercial VALUES ('11323K', 'Luis', 'Canto', 'C/Esplandiu 4', '28033', 1, '913379888', '2') INSERT INTO Comercial VALUES ('22354L', 'Pedro', 'Alcantara', 'C/Portugal 4', '08021', 2, '933485875', '3') INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INTO Oferta (1, 1, 'C/Samba, 4', 1, 'V', 100000, '11323K', '11384H') INTO Oferta (2, 2, 'C/Salca, 34', 2, 'A', 1000, '113384H', '11383K') INTO Oferta (3, 1, 'C/Sabueso, 83', 1, 'V', 100000, '11323K', '11383K') INTO Oferta (4, 2, 'C/Llobregat, 34', 2, 'V', 100000, '11323K', '11384H') INTO Oferta (5, 1, 'C/Alcala, 197', 1, 'A', 500, '113384H', '11384H') INTO Oferta (6, 2, 'C/Alquimia, 34', 2, 'V', 100000, '22354L', '123454L')

143

Bases de datos con SQL Server2000 – Transact SQL

© Grupo EIDOS

INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES

INTO Oferta (7, 1, 'C/Alcosta, 867', 1, 'V', 100000, '11323K', '123454L') INTO Oferta (8, 1, 'C/Lorca, 33', 1, 'V', 100000, '22354L', '11384H') INTO Oferta (9, 1, 'C/Alcantara, 256', 1, 'V', 100000, '11323K', '11384H') INTO Oferta (10, 1, 'C/Arboleda, 32', 1, 'V', 100000, '11323K', '11384H') INTO Oferta (11, 1, 'C/Simbiosis, 32', 1, 'V', 100000, '11323K', '11384H') INTO TipoTransporte (1, 'Metro') INTO TipoTransporte (2, 'Cercanias') INTO TipoTransporte (3, 'Bus') INTO Transporte (1, 'Sol', 1) INTO Transporte (2, 'La Musas', 1) INTO Transporte (3, 'Alvarado', 1) INTO Transporte (4, 'Pacífico', 1) INTO Transporte (5, 'Sants', 1) INTO Transporte (6, 'Atocha', 2) INTO Transporte (7, 'Chamartin', 2) INTO Transporte (8, '12', 3) INTO Transporte (9, '24', 3) INTO Transporte (10, '2', 3) INTO Transporte (11, '123', 3) INTO Transporte (12, '56', 3) INTO Transporte (13, '34', 3) INTO Transporte (14, '5', 3) INTO OfertaTransporte (1, 1) INTO OfertaTransporte (1, 2) INTO OfertaTransporte (1, 3) INTO OfertaTransporte (3, 1) INTO OfertaTransporte (4, 4) INTO OfertaTransporte (4, 5) INTO OfertaTransporte (6, 1) INTO OfertaTransporte (6, 2) INTO OfertaTransporte (6, 6) INTO OfertaTransporte (8, 8)

144

© Grupo EIDOS

15. La sentencia INSERT

INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES

INTO OfertaTransporte (8, 9) INTO OfertaTransporte (8, 10) INTO OfertaTransporte (8, 11) INTO OfertaTransporte (9, 1) INTO OfertaTransporte (9, 8) INTO OfertaTransporte (10, 3) INTO OfertaTransporte (10, 10) INTO OfertaTransporte (10, 11) INTO OfertaTransporte (10, 12) INTO OfertaTransporte (10, 5) Código fuente 88

145

La sentencia SELECT
Introducción
La sentencia select es la principal manera que tiene el usuario de consultar información de la base de datos. Veremos aquí algunos ejemplos de utilización, basándonos en los ejemplos que hemos visto en el capítulo acerca del DDL. La forma más simple de utilización es especificando una lista de atributos de una tabla. Así el Código fuente 89 mostraría todos los datos referentes a comerciales

SELECT * FROM Comercial Código fuente 89

y el Código fuente 90 mostraría el nombre y apellidos de todos los clientes

SELECT Cli_Nombre, Cli_Apellidos FROM Cliente Código fuente 90

Bases de datos con SQL Server2000 – Transact SQL

© Grupo EIDOS

La claúsula WHERE
La forma de especificar una condición dentro de una sentencia select es mediante la claúsula WHERE, que especifica una condición lógica que devolverá únicamente aquellos registros que la cumplan. Por ejemplo, para obtener todos los inmuebles de la tabla de ofertas que se encuentran en venta, deberíamos teclear el Código fuente 91.

SELECT * FROM Oferta WHERE Oferta.Of_Transaccion = ‘V’ Código fuente 91

O si queremos consultar todos los inmuebles cuyo precio oscile entre 100 y 2.000 euros, deberemos ejecutar Código fuente 92.

SELECT * FROM Oferta WHERE Oferta.Of_Precio >= 100 and Oferta.Of_Precio <= 2000 Código fuente 92

Esta sentencia equivaldría a esta otra:

SELECT * FROM Oferta WHERE Oferta.Of_Precio BETWEEN 100

and 2000

Código fuente 93

Si además deseamos especificar un orden, habrá que utilizar la claúsula ORDER BY. Por ejemplo, el Código fuente 94 muestra el precio de todos los inmuebles de 100 a 2.000 euros, ordenado de más caro a más barato, como muestra la Figura 86.

SELECT Oferta.Of_Precio FROM Oferta WHERE Oferta.Of_Precio BETWEEN 100 ORDER BY Oferta.Of_Precio

and 2000

Código fuente 94

148

Prv_ID = Provincia. que se encuentra en otra tabla distinta de la de ofertas. La sentencia SELECT Figura 86 El operador join Si la sentencia select es la más utilizada para consulta de información.Prv_ID Código fuente 95 De esta manera obtenemos la información de la provincia. En el anterior ejemplo se ha utilizado un inner join. Prv_Nombre FROM Oferta Inner join Provincia on Oferta. como pueden ser el left outer y el rigth outer. SELECT Of_Direccion. Si por ejemplo deseamos obtener todas las viviendas que no 149 .© Grupo EIDOS 16. Por ejemplo. deberemos utilizar este operador para obtener la información contenida en ambas. así que no se entrará en detalle. deberemos ejecutar el Código fuente 95. el operador join es el más usado para obtener información de tablas relacionadas. pero también existen otros tipos de join. para obtener una información detallada de en que provincias se encuentran los inmuebles. y que se encuentra relacionada con ésta mediante la clave ajena Prv_ID. Si deseamos obtener datos de dos tablas que están relacionadas por un atributo. La diferencia entre ambos ya se ha comentado en un capítulo anterior.

Cli_NIF = Cliente.Prv_ID = Provincia.Cli_NIF FROM Oferta Inner join Provincia on Oferta. que se encuentren en alquiler y que pertenezcan a la provincia de Madrid. Prv_Nombre.TB_ID = TipoBien.Of_Direccion. obtendremos los clientes que no tienen correspondencia con las ofertas.Prv_Nombre.Prv_ID Left outer join Cliente on Oferta. obtendremos ese atributo a nulo.TB_ID = TipoBien.TB_Nombre = ‘Piso’ WHERE Oferta. Cliente. primero realizamos un inner join para obtener la provincia (caso de que no exista no aparecería nada).vInmuebles SELECT Oferta.Of_Transaccion = ‘A’ Código fuente 97 Aunque el anterior código es válido.Prv_ID = Provincia. si dicho cliente no existe en la base de datos.Bases de datos con SQL Server2000 – Transact SQL © Grupo EIDOS han sido compradas todavía por ningún cliente.TB_ID Código fuente 98 Ya continuación hacer un select de la vista como si de una tabla se tratase: SELECT * FROM vInmuebles 150 .TB_Nombre FROM Oferta INNER JOIN Provincia ON Oferta. Supongamos que ahora nos viene un cliente. Puesto que se ha utilizado una claúsula where que nos devuelve únicamente los clientes que tienen dicho atributo a nulo.Prv_Nombre = ‘Madrid’ inner join TipoBien on Oferta. hubiese sido más cómodo crear una vista como la siguiente: CREATE VIEW dbo. Oferta. y a continuación un left outer join con la tabla de clientes para obtener el cliente que tiene asignado la oferta.Cli_NIF is null Código fuente 96 En el anterior ejemplo.Prv_ID INNER JOIN TipoBien ON Oferta. y nos pregunta por todos los inmuebles. SELECT * FROM Oferta Inner join Provincia on Oferta. o que han sido asignadas a clientes erróneos deberemos ejecutar el Código fuente 96.Of_Transaccion.TB_ID and TipoBien.Prv_ID and Provincia. TipoBien. Provincia. SELECT Of_Direccion. Habría que ejecutar el Código fuente 97.Prv_ID = Provincia. que sean pisos.Cli_NIF WHERE Cliente.

como muestra el Código fuente 103 y podemos apreciar en la Figura 87.TT_Nombre = ‘Metro’ or TipoTransporte. SELECT top 1 Of_Direccion.Tr_ID = Transporte.Cli_NIF is null Código fuente 101 Sin embargo.TT_Nombre = ‘Cercanias’) Código fuente 100 Incluso podemos seleccionar todos los clientes que no han comprado ningún inmueble: SELECT Cliente.Of_ID Transporte on OfertaTransporte.TT_ID = TipoTransporte. Of_Precio FROM Oferta ORDER BY Of_Precio desc Código fuente 103 151 .TT_ID (TipoTransporte.Cli_Nombre FROM Cliente Left outer join Oferta on Oferta. el anterior código podría haberse simplificado de la siguiente manera: SELECT Cli_NIF FROM Cliente WHERE Cli_NIF not in (SELECT Cli_NIF FROM Oferta) Código fuente 102 Las funciones de agregado Imaginemos ahora que deseamos obtener el inmueble más caro de todos. La sentencia SELECT WHERE Of_Transaccion = ‘A’ and TB_Nombre = ‘Piso’ and Prv_Nombre = ‘Madrid’ Código fuente 99 Vamos ahora a por un ejemplo con los transportes. y cogiendo el primer registro de todos (utilizando la claúsula TOP 1). lo cual se obtiene mediante la claúsula ORDER BY <atributo> DESC. Supóngase que se desea saber cuanto valen todos los pisos que están próximos a una estación de cercanías o de metro.Cli_NIF = Cliente.© Grupo EIDOS 16.Tr_ID TipoTransporte on Transporte. obtenemos el inmueble cuyo precio es máximo. El código sería el siguiente: SELECT Of_Precio FROM Oferta Inner join Inner join Inner join And OfertaTransporte on Oferta.Of_ID = Transporte.Cli_NIF WHERE Oferta. Ordenando por precio de manera descendente.

dentro de la consulta especificada. encontramos la función min. que veremos en más detalle a continuación. y análogamente a max. SQL-SERVER nos ofrece otras muchas. De esta manera obtenemos el máximo valor para el atributo que especificamos para dicha función. Por ejemplo. encargada de devolver el registro cuyo valor es el mínimo. SELECT min(Of_Precio) FROM Oferta Inner join Provincia on Provincia. El Código fuente 105 devolvería el inmueble más barato de la provincia de Madrid.Prv_ID = Oferta. T-SQL nos ofrece una forma más sencilla de realizar esta consulta. utilizando una función de agregado que se denomina max.Bases de datos con SQL Server2000 – Transact SQL © Grupo EIDOS Figura 87 Sin embargo. como muestra el siguiente código equivalente: SELECT max(Of_Precio) FROM Oferta Código fuente 104 Además de este función de agregado.Prv_ID and Provincia.Prv_Nombre = ‘Madrid’ Código fuente 105 152 .

Prv_ID = Provincia. SELECT count(*) FROM Oferta Código fuente 107 Y si queremos obtener el número de ofertas existentes en la provincia de Barcelona. pero ahora filtrando por el código de provincia que. La sentencia SELECT Otra función muy usual es la de suma.Cli_NIF and Cliente. SELECT count(*) FROM Oferta Inner join Provincia on Oferta. como no conocemos a priori. es decir. volveremos a utilizar esta sentencia. SELECT avg(Of_Precio) FROM Oferta Inner join Provincia on Oferta. SQL-SERVER nos ofrece la función avg. El Código fuente 107 serviría para contar el número de filas de la tabla Oferta. para un atributo determinado dentro de una consulta.© Grupo EIDOS 16. restringiendo en ésta última tabla por aquellos clientes cuyo atributo apellidos comience por Marti (claúsula like). SELECT sum(Of_Precio) FROM Oferta inner join Cliente on Oferta.Prv_ID And Provincia. dentro de la consulta especificada.Cli_Apellidos like 'Marti%' Código fuente 106 En el anterior código nos basamos en utilizar un join con la tabla de clientes utilizando el atributo común Cli_NIF. el número total de ofertas almacenadas en la base de datos. Por ejemplo. seria equivalente al código que realiza los cálculos por separado. cuya misión es contar es numero de filas que devuelve la consulta. y cuyo cometido es devolver como resultado la suma del atributo especificado entre paréntesis. Si queremos obtener el dinero gastado por un cliente del que sabemos que su apellido empieza por “Marti”. lo más usual es poner el comodín *. bastaría ejecutar el Código fuente 106. En este caso. No menos importante es la función count. expresada por sum. como muestra el Código fuente 108.Prv_Nombre = ‘Barcelona’ Código fuente 108 Para obtener media aritméticas.Prv_ID And Provincia. será necesario obtener por medio de un join que contenga dicho nombre. el código que nos muestra la media del precio de los inmuebles de Barcelona.Prv_ID = Provincia.Cli_NIF = Cliente. aunque se puede especificar un atributo entre paréntesis. ya que el número de filas es similar es para todos los atributos.Prv_Nombre = ‘Barcelona’ Código fuente 109 153 .

Bases de datos con SQL Server2000 – Transact SQL © Grupo EIDOS SELECT sum(Of_Precio) / count(Of_Precio) as media FROM Oferta Inner join Provincia on Oferta.Prv_ID And Provincia. Provincia.Prv_ID Código fuente 111 Sin embargo. deberemos utilizar esta claúsula. y obtenemos algo como la Figura 88. SELECT avg(Of_Precio).Prv_ID GROUP BY Provincia.Prv_ID GROUP BY Provincia. la desviación típica de la población (stdevp).Prv_ID = Provincia. y Prv_Nombre puede que no sea único. SELECT avg(Of_Precio). en principio deberíamos ejecutar el Código fuente 111.Prv_Nombre FROM Oferta Inner join Provincia on Oferta. si ejecutamos este código.Prv_Nombre WHERE avg(Of_Precio) > 100000 Código fuente 113 154 . lo lógico sería ejecutar el código. ya que avg devuelve un registro. la varianza estadística (var) y la varianza de llenado (varp). en lugar de a registros por si solos. Provincia. Provincia. por lo que SQL SERVER se hace “un lio”. Para entendernos. Si por ejemplo deseamos obtener la media del precio de los pisos por provincias. La claúsula GROUP BY Si deseamos obtener agrupaciones dentro de una consulta.Prv_ID = Provincia. SELECT avg(Of_Precio). nos mostraría un error. es como un where pero que se aplica a grupos de registros. Para evitar esto. Modificamos el código para utilizar esta cláusula. debemos utilizar es la claúsula group by.Prv_Nombre Código fuente 112 Paralelamente al uso de group by se suele utilizar la claúsula having. para obtener los resultados agrupados.Prv_Nombre FROM Oferta Inner join Provincia on Oferta.Prv_Nombre FROM Oferta Inner join Provincia on Oferta.Prv_Nombre = ‘Barcelona’ Código fuente 110 El funcionamiento es similar para las funciones encargadas de calcular la desviación típica (stdev). Si modificamos la anterior consulta para que sólo se devuelvan aquellas provincias cuya media de precio supera los 100.Prv_ID = Provincia.Prv_ID = Provincia.000 euros. entonces tendremos un avg por cada grupo que obtengamos.

Provincia. Sustituimos el where por having en el Código fuente 114. SELECT Prv_Nombre FROM Oferta inner join Provincia on Oferta.Prv_Nombre HAVING avg(Of_Precio) > 100000 Código fuente 114 Otra utilidad que ofrece la cláusula group by es la de obtener los valores distintos que aparecen para uno o varios atributos. para obtener cuales son las provincias en las cuales tenemos algún inmueble.© Grupo EIDOS 16.Prv_Nombre FROM Oferta Inner join Provincia on Oferta. al estar utilizando group by deberemos especificar una función de agregado. Por ejemplo. La sentencia SELECT Figura 88 Sin embargo esto nos devuelve un error.Prv_ID Código fuente 115 155 . podríamos ejecutar el código.Prv_ID = Provincia.Prv_ID = Provincia. ya que el where se aplica a registros y.Prv_ID GROUP BY Provincia. SELECT avg(Of_Precio).

Prv_ID = Provincia. podemos utilizar la función dinstinct.Bases de datos con SQL Server2000 – Transact SQL © Grupo EIDOS Sin embargo. esto nos devuelve un registro por cada oferta que se encuentre.Prv_ID GROUP BY Prv_Nombre Código fuente 117 156 . SELECT distinct(Prv_Nombre) FROM Oferta inner join Provincia on Oferta. que sí se resolvería utilizando la claúsula group by. Prv_Nombre FROM Oferta inner join Provincia on Oferta. como sigue. como muestra el Código fuente 117. Para evitar esto. SELECT count(Prv_Nombre) Cantidad.Prv_ID Código fuente 116 Sin embargo esto no es válido si queremos realizar algún tipo de información adicional.Prv_ID = Provincia. por ejemplo contar el número de inmuebles por provincia. con los consiguientes duplicados.

Su sintaxis es la siguiente. éstas se deberán separar por comas. 5' . La claúsula FROM se puede omitir. la sentencia update se utiliza para modificar la información existente. que será la misma que la que se actualice. UPDATE Comercial SET Com_Direccion = 'C/Esplandiu. en el caso de sólo se necesite acceder a una tabla. que se muestra en el Código fuente 118 donde se actualiza la dirección del comercial cuyo NIF es 11323K.La sentencia UPDATE Introducción Esta sentencia es la que permite la actualización de la información almacenada en la base datos. UPDATE <tabla> SET <atributo> = <valor> FROM <tablas> WHERE <condicion> Si se especifica más de una asignación de un valor a un atributo. Ejemplos Para comenzar veremos un ejemplo sencillo. Si la sentencia insert se utilizaba para añadir nueva información.

Prv_ID = Provincia. obteniendo el resultado de la Figura 89. Provincia WHERE Comercial. SELECT Com_NIF. UPDATE Comercial SET Com_Categoria = '4' FROM Comercial. ejecutando el Código fuente 119. Por ejemplo. para la cual se deberá ejecutar el Código fuente 120. sino que se pueden actualizar todas las filas que coincidan con un criterio de búsqueda.Prv_ID and Prv_Nombre = 'Madrid' Código fuente 120 158 . vamos a consultar los datos de este comercial. se puede hacer subir a la categoría 4 a todos los comerciales de Madrid.Bases de datos con SQL Server2000 – Transact SQL © Grupo EIDOS WHERE Com_NIF = '11323K' Código fuente 118 Para comprobar que efectivamente el cambio ha tenido efecto. Com_Direccion FROM Comercial WHERE Com_NIF = '11323K' Código fuente 119 Figura 89 Pero no simplemente se puede actualizar una fila cada vez.

UPDATE Cliente SET Cli_Direccion = 'C/Apache 35'. el Código fuente 122 muestra como actualizar la dirección y el teléfono del cliente Juan Jose Martinez. Prv_Nombre FROM Comercial. ya que necesitábamos conocer el identificador correspondiente a la provincia de Madrid. es posible actualizar más de uno simultáneamente.© Grupo EIDOS 17. Por ejemplo. Cli_Telefono = '912237887' WHERE Cli_Nombre = 'Juan Jose' and Cli_Apellidos = 'Martinez' Código fuente 122 159 . Provincia WHERE Comercial. ejecutamos el Código fuente 121. Para comprobar si se han actualizado los datos. SELECT Com_Categoria. La sentencia UPDATE En este caso hemos tenido que especifica la claúsula from para acceder a la tabla de provincias. aunque no sea ésta la que se actualice.Prv_ID Código fuente 121 Figura 90 Hasta ahora sólo hemos actualizado un atributo. pero como hemos dicho. y sólo los correspondientes a la provincia de Madrid.Prv_ID = Provincia.

Primero ejecutaremos el Código fuente 124 para comprobar cual es el precio de estos inmuebles. 160 .Prv_ID where Prv_Nombre = 'Barcelona' Código fuente 124 Ahora ejecutamos el Código fuente 125 para actualizar su precio a un 5% más de su valor actual. Prv_Nombre FROM Oferta inner join Provincia on Provincia.Prv_ID = Oferta. podemos subir el precio de todos los inmuebles de Barcelona un 5%. SELECT Of_Precio. no hace falta especificar un valor a la hora de actualizar uno o varios atributos. obteniendo el resultado de la Figura 91. sino que se puede indicar una expresión. Por ejemplo. ejecutamos el Código fuente 123.Bases de datos con SQL Server2000 – Transact SQL © Grupo EIDOS Para comprobar que se ha actualizado correctamente el registro. SELECT * FROM Cliente WHERE Cli_Nombre = 'Juan Jose' and Cli_Apellidos = 'Martinez' Código fuente 123 Figura 91 Del mismo modo.

para el cálculo de expresiones. update nos permite la utilización de las funciones de agregación. y así sucesivamente. la categoría a asignar será de 1. Para calcular dicha categoría podemos aplicar la siguiente fórmula: Categoria = (nº inmuebles vendidos / 2) + (nº inmuebles vendidos módulo 2) El operador de módulo o resto de la división entera se representa en T-SQL como %. entre 3 y 4 será 2. y 4 para Luis.Prv_ID = Oferta. SELECT count(*) cantidad. Por ejemplo.Com_NIF)) Código fuente 128 161 .Prv_ID = Oferta. actualizaremos la categoría del comercial dependiendo del número de inmuebles que haya vendido cada uno. Provincia WHERE Provincia. Com_Nombre FROM Comercial left outer join Oferta on Oferta. Ejecutemos ahora el Código fuente 128 que nos permite hacer esto.Com_NIF GROUP BY Comercial. primero veamos cuantos inmuebles ha vendido cada comercial.05) FROM Oferta. Prv_Nombre FROM Oferta inner join Provincia on Provincia.Prv_ID where Prv_Nombre = 'Barcelona' Código fuente 126 De la misma forma que para la sentencia select.© Grupo EIDOS 17.Com_NIF = Oferta.Com_NIF) + (SELECT count(*) % 2 FROM Oferta where Comercial.Prv_ID and Prv_Nombre = 'Barcelona' Código fuente 125 Y para comprobar que efectivamente se han actualizado estos registros. Si ha vendido entre 0 y 2. ejecutando la sentencia del Código fuente 127.Com_Nombre Código fuente 127 Por lo tanto vemos que la asignación de categorías sería 1 para Juan Alberto y Pedro. Vayamos paso a paso. ejecutamos nuevamente el Código fuente 126. La sentencia UPDATE UPDATE Oferta SET Of_Precio = Of_Precio + (Of_Precio * 0.Com_NIF = Oferta. UPDATE Comercial SET Com_Categoria = ((SELECT count(*) / 2 FROM Oferta where Comercial. entre 5 y 6 será 3. SELECT Of_Precio.Com_NIF = Comercial.

para dividirlo por 2. Si ejecutamos una selección.Bases de datos con SQL Server2000 – Transact SQL © Grupo EIDOS Lo primero que se ha hecho es para cada comercial calcular el número de ofertas que tiene relacionado. nos encontraríamos con lo siguiente. calcular su módulo 2 y luego sumarlo y asignarlo al campo categoría. como la que se muestra en el Código fuente 129 para comprobar que efectivamente la actualización se ha realizado con éxito. SELECT Com_Nombre. Com_Categoria FROM Comercial Código fuente 129 162 .

podemos obtener el máximo valor para el atributo Of_ID. DELETE FROM tabla WHERE condicion Donde tabla especifica el nombre de la tabla de donde se desean borrar las filas que cumplen la condición especificada en la claúsula where. y comprobar que no es superior a 10.La sentencia DELETE Introducción La sentencia delete es la que nos permite borrar tuplas almacenadas en la base de datos. Su sintaxis es la siguiente. podemos hacer una select completa de la tabla y verificar que falta dicho registro aunque. . ejecutando el Código fuente 130. Si ésta se omite. DELETE FROM Oferta WHERE Of_ID = 11 Código fuente 130 Para comprobar si se ha borrado dicho registro. lo más sencillo. nos encontraremos con que se borrará la oferta cuyo código es 11 de la tabla de ofertas. y conociendo que el registro que hemos borrado era el último introducido. Si por ejemplo ejecutamos el Código fuente 130. se borrarán todas las filas de la tabla especificada (mucho cuidado con esto).

primero deberemos borrar éstas. hacen referencia a comerciales que ya no existen en la base de datos. para evitar posibles inconsistencias que pudieran surgir al eliminar atributos que son clave ajena en otra relación.Com_NIF = Comercial. como muestra el Código fuente 134. ejecutaremos el Código fuente 132. es decir. evitando esta pérdida de información. al ejecutar este código nos encontramos en la misma situación. ya que resulta que existen filas en la tabla que relaciona las ofertas y los transportes. Recordemos al lector que estas reglas son las que permiten mantener la información de la base de datos en un estado coherente. cuando pretendamos borrar una tupla de estas características. nos da un error.Com_NIF and Com_Nombre = 'Luis' and Com_Apellidos = 'Canto' Código fuente 133 Sin embargo.Bases de datos con SQL Server2000 – Transact SQL © Grupo EIDOS SELECT max(Of_ID) FROM Oferta Código fuente 131 La integridad referencial Un aspecto a tener en cuenta es el no violar las reglas de integridad referencial que sostienen la base de datos. Para comprender mejor esto. las reglas de integridad nos permiten olvidarnos a la hora de borrar un registro. DELETE FROM Oferta FROM Comercial 164 . Por lo tanto. DELETE FROM Oferta FROM Comercial Where Oferta. Es decir. si por ejemplo queremos borrar el comercial Luis Canto. supongamos que borramos todos los comerciales de la base de datos. primero deberemos borrar todas las ofertas en las que haya participado dicho comercial. Para evitar esto. De esta manera. que hacen referencia a dicha oferta. como cabía esperar. DELETE FROM Comercial Where Com_Nombre = 'Luis' and Com_Apellidos = 'Canto' Código fuente 132 que. ejecutando el Código fuente 133. Esto supondría que tendríamos ofertas inconsistentes. Si lo hemos hecho bien. el SGBD nos advertirá de ello y no nos dejará borrarla. si éste esta relacionado con alguna otra tabla.

DELETE FROM Comercial Where Com_Nombre = 'Luis' and Com_Apellidos = 'Canto' Código fuente 136 La sentencia TRUNCATE TABLE Esta sentencia funciona de la misma forma que la instrucción delete sin especificar una cláusula WHERE: ambas quitan todas las filas de la tabla. sin preocuparnos de posibles inconsistencias. se debe utilizar delete en su lugar.Com_NIF = Comercial. La sentencia DELETE Where Oferta. índices. etc.© Grupo EIDOS 18. el Código fuente 137 borraría todos los datos de la tabla Cliente TRUNCATE TABLE Cliente Código fuente 137 165 .Com_NIF = Comercial. TRUNCATE TABLE quita los datos al cancelar la asignación de las páginas de datos utilizadas para almacenar los datos de la tabla y sólo se graba en el registro de transacciones la página de asignaciones quitadas. El contador utilizado por una identidad para las nuevas filas se restablece al valor de inicialización de la columna. ya le podemos eliminar de la base de datos. ejecutando el Código fuente 135.Com_NIF and Com_Nombre = 'Luis' and Com_Apellidos = 'Canto' Código fuente 134 Una vez borradas las filas de OfertaTransporte. pero permanece la estructura y sus columnas. con el Código fuente 136. DELETE FROM Oferta FROM Comercial Where Oferta. volvemos atrás para borrar las filas de Oferta.Com_NIF and Com_Nombre = 'Luis' and Com_Apellidos = 'Canto' Código fuente 135 Y una vez borradas las ofertas de dicho comercial. Por ejemplo. Si desea conservar el valor del contador. TRUNCATE TABLE quita todas las filas de una tabla. Pero TRUNCATE TABLE es más rápida y utiliza menos recursos de los registros de transacciones y de sistema que delete. La instrucción DELETE quita una a una las filas y graba una entrada en el registro de transacciones por cada fila eliminada. restricciones.

Bases de datos con SQL Server2000 – Transact SQL © Grupo EIDOS Ejemplos Veamos ahora algunos ejemplos para afianzar al lector en el uso de esta sentencia. ejecutando el Código fuente 139. Para ello ejecutamos el Código fuente 138 DELETE FROM OfertaTransporte WHERE Of_ID in (SELECT Of_ID FROM Oferta WHERE Prv_ID in (SELECT Prv_ID FROM ComunidadAutonoma.CA_ID)) Código fuente 138 De esta manera y. Por ejemplo. utilizando para ello el operador de contenido (in). si queremos borrar todas las ofertas de la Catalunya. Sin embargo. se puede utilizar el resultado de una subconsulta para borrar un conjunto de registros. Por ejemplo. para a continuación efectuar el borrado de toda las ofertas que contengan dicho identificador. Provincia WHERE ComunidadAutonoma. se puede indicar una consulta. podemos utilizar una subconsulta que nos devuelva los identificadores de las provincias pertenecientes a dicha comunidad. para lo cual podemos volver a ejecutar una subconsulta en un segundo nivel para obtener dichas filas. primero habrá que borrar todas las filas de OfertaTransporte que estén relacionadas con éstas.CA_ID = Provincia. Por ejemplo. DELETE Oferta FROM (SELECT top 2 * FROM Oferta) as t Código fuente 140 Puesto que esto devuelve un error debido a la integridad referencial. DELETE FROM Oferta WHERE Prv_ID in (SELECT Prv_ID FROM ComunidadAutonoma.CA_Nombre = 'Catalunya' and ComunidadAutonoma. Provincia WHERE ComunidadAutonoma. el Código fuente 140 mostraría como borrar las dos primeras ofertas.CA_ID = Provincia.CA_Nombre = 'Catalunya' and ComunidadAutonoma. borraremos las ofertas como era nuestra pretensión. una vez borradas todos los transportes disponibles para la oferta. deberemos ejecutar primero el Código fuente 141que elimine las filas de OfertaTransporte relacionadas. y al igual que hacíamos con la sentencia select. 166 .CA_ID) Código fuente 139 Además de especificar una tabla en una sentencia delete.

Of_ID = OfertaTransporte. por ejemplo. que nos servirá para luego hacer referencia a dicha subconsulta en la claúsula where. que permita borrar dichas filas. Aquí. que permita borrar dichas filas. se utiliza para hacer un join con la tabla OfertaTransporte. En este código. por ejemplo. La sentencia DELETE DELETE OfertaTransporte FROM (SELECT top 2 * FROM Oferta) as t WHERE t.© Grupo EIDOS 18.Of_ID Código fuente 141 En este código. se ha utilizado una subconsulta como tabla. especificando para la misma un alias (t). se utiliza para hacer un join con la tabla OfertaTransporte. 167 . especificando para la misma un alias (t). se ha utilizado una subconsulta como tabla. que nos servirá para luego hacer referencia a dicha subconsulta en la claúsula where. Aquí.

.

Por ejemplo.Procedimientos almacenados y triggers Introducción Los procedimientos almacenados son conjuntos de sentencias en leguaje Transact SQL que pueden almacenarse en el propio servidor. cuyo código coincida con el parámetro. porque permiten almacenar funciones y procedimientos compuestos por varias instrucciones.au_id = @au_id Código fuente 142 Con esta sentencia. También se pueden compilar procedimiento escritos en lenguaje C. Los procedimientos almacenados de SQL Server. etc. son más potentes. deberemos ejecutar el procedimiento pasándole como argumento este valor: . introducir saltos. podemos crear un procedimiento para recuperar el nombre de un autor. De esta forma. llamado @au_id. de tipo varchar(11). que realiza una consulta para obtener el nombre de la tabla author. de nombre ObtenerNombre. bucles. al que se le pasa un parámetro. si queremos obtener el nombre del autor cuyo código sea '123'. se crea un procedimiento almacenado. CREATE PROCEDURE ObtenerNombre @au_id varchar(11) AS SELECT au_name FROM author WHERE author. cuyo código se pasa por parámetro. para ampliar su potencia modularmente.

CREATE SELECT SELECT SELECT SELECT RETURN PROCEDURE num_autores_libros @autores int OUTPUT. La función @@ROWCOUNT devuelve el número de filas que se han seleccionado. Detrás de la palabra reservada PROCEDURE damos el nombre del procedimiento almacenado. y diremos sin éstos son de salida. igualando el parámetro al valor. ObtenerNombre @au_id = '123' Código fuente 144 Parámetros por referencia Si ejecutamos las anteriores sentencias. queremos obtener el número de autores y el número de libros que tenemos en la base de datos. @libros int OUTPUT AS * FROM Authors @autores = @@ROWCOUNT * FROM Titles @libros = @@ROWCOUNT (0) Código fuente 145 Vamos a estudiar el anterior ejemplo. y a continuación proporcionamos los parámetros.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Las llamadas a procedimientos almacenados se pueden realizar de las siguientes formas: • Pasando los argumentos en el mismo orden que en el que se han declarado. realizando un SELECT * FROM Authors. en cuyo caso especificamos la palabra reservada OUTPUT a continuación. Básicamente es similar al anterior. Nótese como la forma de asignar un valor a un atributo es mediante una sentencia SELECT. En este caso no hace falta que los parámetros vayan en el mismo orden. Si por ejemplo. Acto seguido se realiza lo mismo para la tabla titles. como resultado de la ejecución del procedimiento?. Tras la palabra reservada AS se codifica el cuerpo del procedimiento. utilizando @@ROWCOUNT. A continuación devolvemos en el parámetro @autores el valor obtenido. Pero ¿que pasa si queremos obtener un parámetro de salida. Primero contamos todas las filas de la tabla authors. ObtenerNombre '123' Código fuente 143 • Pasando los argumentos nombrados. crearemos el procedimiento almacenado que muestra el Código fuente 145. obtendremos el resultado directamente en la ventana que tengamos abierta en SQL Server. La solución para este caso es utilizar la palabra reservada OUTPUT para los argumentos de salida. junto con su tipo (que en este caso es entero). Es equivalente a la sentencia que aparece en el Código fuente 146 170 .

por lo tanto. seguido del nombre de la variable y el tipo.© Grupo EIDOS 19. y los parámetros. EXEC num_autores_libros @num_autores OUTPUT. @libros int OUTPUT AS @autores = (SELECT COUNT(*) FROM Authors) @libros = (SELECT COUNT(*) FROM Authors) (0) Código fuente 147 Para ejecutar el anterior procedimiento. @num_libros OUTPUT Código fuente 149 3. Ejecutar el procedimiento. SELECT autores = @num_autores. separados por comas. La sintaxis para declarar una variable es utilizar la palabra reservada DECLARE. Declarar las variables que vamos a utilizar para llamar al procedimiento. DECLARE @num_autores int DECLARE @num_libros int Código fuente 148 2. La sintaxis es utilizar la palabra reservada EXEC. se podría sustituir por Código fuente 147. Procedimientos almacenados y triggers SELECT COUNT(*) FROM Authors Código fuente 146 El Código fuente 146. seguida del nombre del procedimiento. libros = @num_libros Código fuente 150 Tras ejecutar las anteriores sentencias. Mostrar los resultados. especificando si son de retorno. seguiremos los siguientes pasos: 1. CREATE SELECT SELECT RETURN PROCEDURE num_autores_libros @autores int OUTPUT. obtendremos como resultado el siguiente listado: autores libros ----------------------------23 18 (1 row(s) affected) 171 .

obtendremos una lista con todos los usuarios conectados. cada uno con su propio objetivo o fin.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Si queremos borrar un procedimiento almacenado. Del mismo modo. listos para ejecutar. ejecutaremos la sentencia DROP PROCEDURE. Por ejemplo. si deseamos conocer todos los atributos de una tabla. seguido del nombre del procedimiento. si escribimos sp_who. creado en el anterior ejemplo. deberemos ejecutar sp_columns seguido del nombre de la tabla. Si queremos obtener una lista con todas las tablas del sistema. si deseamos saber los usuarios conectados a nuestro sistema. Por ejemplo. disponemos de otro procedimiento almacenado denominado sp_tables. 172 . es decir. Figura 92 Así. o ejecutar el procedimiento almacenado sp_who. podemos elaborar una consulta SELECT sobre la tabla de sistema que contiene los usuarios conectados. escribiremos el Código fuente 151 DROP PROCEDURE num_autores_libros Código fuente 151 Procedimientos almacenados de sistema SQL Server nos ofrece una serie de procedimientos almacenados ya implementados. si queremos borrar el procedimiento almacenado. como podemos observar en la Figura 92.

© Grupo EIDOS

19. Procedimientos almacenados y triggers

Por ejemplo, para listar los atributos de la tabla authors ejecutamos sp_columns authors, y obtenemos el resultado de la Figura 93 Existe una gran variedad de procedimientos almacenados, como por ejemplo para crear dispositivos, para comprobar el espacio usado por una tabla, etc. Aquí sólo hemos visto dos ejemplos de aplicación.

Figura 93

Extended stored procedures
Una de las principales ventajas que ofrece SQL Server es que permite la ejecución de procedimientos almacenados escritos en otro lenguaje de programación, como por ejemplo C, aprovechando de este modo toda la potencia que ofrece un compilador de este estilo. De todos es conocida la potencia que ofrece el lenguaje C, ya que es un compilador a bajo nivel. Esto es, permite interaccionar con el hardware, obtener datos del Sistema Operativo, etc. La técnica que permite el aprovechamiento de un lenguaje externo a SQL Server, para el diseño de procedimientos almacenados se denomina Extended Stored Procedures. Este es un caso un poco más complicado que el manejo de procedimientos almacenados intrínsecos al propio SQL Server. Los Extended Stored Procedures se implementan como DLLs, que serán privadas a SQL Server, y cuya gestión del espacio de memoria corresponde a éste. Una DLL (Dinamic Link Library) es un conjunto de funciones, que se cargan dinámicamente en memoria, esto es, se cargan en memoria cuando vayan a ser usadas, y se descargan cuando no se necesiten. Si por ejemplo, uno de estos procedimientos intenta acceder a una dirección que cae fuera del espacio de

173

Bases de datos con SQL Server 2000 – Transact SQL

© Grupo EIDOS

direcciones permitido, SQL Server atrapa la excepción, mata la tarea, y libera los bloqueos, continuando normalmente con su trabajo. Para registrar una Extended Stored Procedure, el administrador del sistema deberá ejecutar la sentencia en Transact SQL que aparece en el Código fuente 152.

sp_addextendedproc nombre_función, nombre_DLL Código fuente 152

Para ejecutar una de estas funciones en una base de datos distinta de aquella en la que se ha registrado, se deberá preceder el nombre de la base de datos al nombre de la función. Hay que destacar que estos procedimientos únicamente podrán ser ejecutados y registrados por el administrador del sistema. Si éste desea permitir la ejecución a los demás usuarios, deberá ejecutar el Código fuente 153.

GRANT EXEC ON procedimiento TO PUBLIC Código fuente 153

Esta sentencia SQL otorga (GRANT) privilegios de ejecución (EXEC) sobre el procedimiento especificado, a todos los usuarios de la base de datos. Si sólo deseamos otorgar este privilegio a un usuario, deberemos especificar su identificador de usuario tras TO.

Triggers
Los disparadores de procedimiento, más comúnmente conocidos como triggers, son una especie de procedimientos almacenados, a diferencia que se ejecutan cuando ocurre un evento sobre alguna tabla. Entendemos por evento, cualquier acción del tipo: • • • Inserción Borrado Actualización

La sintaxis de la sentencia de creación de triggers es la siguiente: CREATE TRIGGER nombre ON tabla FOR accion AS codigo donde acción especifica el evento que debe ocurrir para que se dispare el trigger, y que puede ser: • • •
174

UPDATE: actualización. INSERT: inserción. DELETE: borrado.

© Grupo EIDOS

19. Procedimientos almacenados y triggers

Por ejemplo, si queremos crear un trigger llamado modificación_autor, sobre la tabla Authors, que muestre un mensaje cada vez que se actualiza una fila de la tabla, deberemos escribir el Código fuente 154.

CREATE TRIGGER modificacion_autor ON authors FOR UPDATE AS print "Han actualizado la tabla de autores" Código fuente 154

Para comprobar el funcionamiento de este trigger, podemos actualizar cualquier fila de la tabla de autores, por ejemplo con la sentencia que aparece en el Código fuente 155.

UPDATE authors SET au_fname

= 'Miguel' WHERE au_id = '267-41-2394' Código fuente 155

Con esto conseguimos dos cosas, actualizar el nombre del autor cuyo código es el especificado a Miguel, y obtener el mensaje que se muestra como ejecución del trigger de actualización. Sin embargo, los triggers en SQL Server tienen una serie de limitaciones: 1. No se puede disparar un trigger dentro de otro trigger, ya que daría lugar a un bucle infinito 2. Por esta razón, un trigger no puede ejecutar instrucciones DDL (lenguaje de definición de datos) 3. No se pueden ejecutar sentencias como SELECT INTO o de creación de dispositivos dentro de un trigger Del mismo modo, para borrar un trigger, deberemos ejecutar la sentencia DROP TRIGGER trigger. Por ejemplo, si queremos borrar el trigger anteriormente creado, ejecutaremos el Código fuente 156

DROP TRIGGER modificacion_autor Código fuente 156

175

y se ejecutará el insert. etc. como pueden ser las de control de flujo. . Por ejemplo. siendo el servidor el encargado de realizar las operaciones. en cuyo caso la condición es verdadera. El Código fuente 157 muestra un procedimiento almacenado encargado de insertar un nuevo tipo de transporte si no está dado de alta en la base de datos. pueden ser llamados desde otras aplicaciones. que permite al usuario que los usa abstraerse de la complejidad interna que puede encerrar.. ELSE Esta sentencia permite evaluar una expresión y provocar la entrada o ejecución de un bloque u otro. las de iteración. Los procedimientos almacenados suelen utilizar sentencias de diverso tipo de T_SQL.. La sentencia IF . que veremos en detalle mediante algunos ejemplos prácticos. con los parámetros adecuados. descargando de trabajo al cliente. Para ello se comprueba que el número de filas que devuelve el select sea cero. dependiendo de que la condición sea verdadera o falsa.Ejemplos prácticos de uso de procedimientos almacenados Introducción Los procedimientos almacenados es una de las principales funcionalidades que ofrece SQL-Server..

'Tranvía' Código fuente 158 Para comprobar lo que ha ocurrido en la tabla de tipos de transporte.end el bloque que deseamos se ejecute cuando se cumple la condición. exec sp_Insertar_TipoTransporte 1. Podemos hacerlo un poco más elegante. y otro que no exista.. @TT_Nombre) Código fuente 157 Probemos a insertar un tipo de transporte que exista. @error char(1) output AS if (select count(*) from TipoTransporte where TT_ID = @TT_ID) = 0 begin set @error = 'N' insert into TipoTransporte values (@TT_ID. ejecutamos el siguiente código. para comprobar como funciona. 178 . Para ello ejecutamos el Código fuente 158. CREATE PROCEDURE sp_Insertar_TipoTransporte @TT_ID int. que devolverá ‘S’ si se ha producido error. necesitamos un parámetro más de llamada. cuyo tipo debe coincidir con el tipo del parámetro de salida declarado en el procedimiento. y es que se ha encerrado entre las palabras begin.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS CREATE PROCEDURE sp_Insertar_TipoTransporte @TT_ID int.. SELECT * FROM TipoTransporte Código fuente 159 Y como podemos comprobar. 'Metro' exec sp_Insertar_TipoTransporte 4. Para ejecutar ahora el procedimiento. sólo se ha insertado el último registro. y ‘N’ si se ha insertado el registro con éxito. además del uso de la sentencia set para asignar un valor a un parámetro o variable. @TT_Nombre varchar(40) AS if (select count(*) from TipoTransporte where TT_ID = @TT_ID) = 0 insert into TipoTransporte values (@TT_ID. @TT_Nombre varchar(40). @TT_Nombre) end else set @error = 'S' Código fuente 160 Podemos observar una novedad. y devolver un parámetro que nos indique si ha habido error o no.

equivaldría al siguiente. lo que indica que se ha producido un error.. lo que indica que el registro se ha insertado correctamente. efectivamente. al ser un inner join. se devuelve una ‘S’. @error output select @error Código fuente 161 Al ejecutar este código. con el fin de mostrar un mensaje determinado. utilizando case.Prv_Nombre = @Prv) > 0 print 'Hay comerciales asociados a la provincia de ' + @Prv else print 'No hay comerciales asociados a la provincia de ' + @Prv Código fuente 163 En este código podemos comprobar como se obtiene el número de registros de un inner join. @error output select @error Código fuente 162 Otro ejemplo nos muestra como comprobar si existen filas para un parámetro determinado.© Grupo EIDOS 20. Si dicho atributo es nulo. que o bien no existe la provincia. CREATE PROCEDURE sp_Hay_Comerciales @Prv varchar(40) AS if (select count(*) from Provincia inner join Comercial on Comercial. si ejecutamos este otro código. Ejecutemos el procedimiento para comprobar si existen comerciales para la provincia de Barcelona.. 179 . declare @error char(1) exec sp_Insertar_TipoTransporte 5. Por ejemplo... Ejemplos prácticos de uso de procedimientos almacenados declare @error char(1) exec sp_Insertar_TipoTransporte 1.else es la sentencia case. al no existir todavía en la base de datos. querrá decir. el código expuesto antes utilizando if. se devolverá una ‘N’. 'Aeropuerto'. exec sp_Hay_Comerciales 'Barcelona' Código fuente 164 La sentencia CASE Una variante a la instrucción if. para obtener el identificador de la provincia que coincide con el nombre que se pasa como parámetro. muy útil sobre todo cuando tenemos muchos if anidados. o bien no existe ningún comercial asociado a ella. Sin embargo. 'Metro'.Prv_ID = Provincia.else.Prv_ID and Provincia. mostramos el parámetro de salida y vemos como.

Exec (‘select * from Provincia’) Código fuente 166 Esto puede resultar muy útil para montar sentencias en tiempo de ejecución. se realizará una búsqueda de todos los clientes que sean de esta provincia. El siguiente código mostraría un procedimiento almacenado que se encarga de realizar búsquedas de clientes. pero no sólo eso. Si se especifica únicamente la provincia. por este atributo. CREATE PROCEDURE sp_Clientes @Prv varchar(40). se realizará una búsqueda. Recibe dos parámetros.Prv_ID and Provincia. el siguiente código muestra como ejecutar un select de todas las provincias.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS CREATE PROCEDURE sp_Hay_Comerciales2 @Prv varchar(40) AS select case (select count(*) from Provincia inner join Comercial on Comercial. Por ejemplo. uno es la provincia y otro es el código postal.La variable condicion almacena la claúsula where y la variable join los join declare @condicion varchar(255) declare @join varchar(255) set @condicion = '' set @join = '' -. o para los cuales deseamos realizar un tratamiento distinto dependiendo de los valores que tomen. sino que además sirve para evaluar una expresión de tipo carácter. además.Prv_Nombre = ' + '''' + @Prv + '''' set @join = ' inner join Provincia on Provincia.Si se ha especificado el cod postal. cuyos valores no conocemos a priori.Prv_ID = Cliente.Prv_ID' end -. montar la condicion y el join if not @Prv is null begin set @condicion = ' Provincia.Prv_ID = Provincia. @CP varchar(5) AS -. la instrucción exec se utiliza para ejecutar un procedimiento almacenado. mientras que si especifica el código postal.Si se ha especificado la variable @Prv.Prv_Nombre = @Prv) when 0 then 'No hay comerciales asociados a la provincia de ' + @Prv else 'Hay comerciales asociados a la provincia de ' + @Prv end Código fuente 165 Ejecución dinámica de sentencias: la instrucción EXEC Como hemos visto. concatenar la condición if not @CP is null begin if @condicion <> '' set @condicion = @condicion + ' and ' 180 .

dependiendo de los parámetros que se indiquen. Ejemplos prácticos de uso de procedimientos almacenados set @condicion = @condicion + ' Cli_CodPostal = ' + '''' + @CP + '''' end if @condicion <> ‘’ set @condicion = ‘ where ‘ + @condicion exec ('select * from cliente ' + @join + @condicion) Código fuente 167 Manejamos dos variables.© Grupo EIDOS 20. que se ira concatenando. Si ejecutamos el anterior procedimiento almacenado. Dichas instrucciones son cast y convert. obtendremos todos los clientes de la provincia de Madrid exec sp_Clientes ‘Madrid’. null Código fuente 168 Si especificamos el parámetro provincia = Madrid. obtendremos todos los clientes exec sp_Clientes null. Es entonces cuando intervienen dos instrucciones que nos permiten realizar esto. Convert (tipo. Cast (expresion as tipo) y la de convert. sin especificar ninguno de los parámetros. exec sp_Clientes 'Madrid'. obtendremos lo siguiente. 28023 Código fuente 170 Conversión de tipos Muchas veces nos encontraremos la necesidad de convertir un valor de un tipo a otro tipo para operar con él. expresion) 181 . y otra almacenará el join que se deberá realizar con la tabla de provincia. Una vez montadas estas cadenas. null Código fuente 169 Si además especificamos el parámetro codigo postal. una almacenará la condición. se ejecuta la sentencia exec. La sintaxis de la expresión cast es la siguiente. para evaluar la expresión resultante. en el caso de que se especifique como parámetro el nombre de la provincia.

hasta que alguno supera el valor de 6. Su sintaxis es la siguiente.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Por ejemplo. WHILE expresion sentencias [BREAK] [CONTINUE] La claúsula break es optativa y indica al bucle que deje de ejecutarse. podemos utilizarlo para convertir un tipo de datos carácter a fecha. En el siguiente ejemplo. Cast (‘01/01/01’ as datetime) Código fuente 171 O un carácter a entero cast (‘3’ as int) Código fuente 172 La sentencia WHILE La instrucción while permite iterar un numero de veces que no conocemos a priori. CREATE PROCEDURE sp_ActualizaComercial AS WHILE (SELECT Com_Categoria FROM Comercial) <> '6' BEGIN UPDATE Comercial SET Com_Categoria = cast(Com_Categoria as int) * 2 IF (SELECT MAX(Com_Categoria) FROM Comercial) > 6 BREAK ELSE CONTINUE END Código fuente 173 182 . y va duplicando la misma. mientras que la categoría sea distinta de 6. mientras que la claúsula continue. que también es optativa. indica al bucle que se reinicie. hasta que deje de cumplirse la condición boleana. se recorre los comerciales.

Por ejemplo. o un borrado de una tabla. pero con ciertas limitaciones. INSERT y UPDATE corresponden a cada una de las acciones para las cuales se puede definir un desencadenador dentro de la tabla especificada. sino que simplemente se ejecuta para cambiar o comprobar los datos que se van a insertar. los triggers o desencadenadores son una especie de procedimientos almacenados.Triggers en SQL-Server 2000 Introducción Como ya se ha comentado. Así. . se ejecutarían las sentencias definidas para el trigger en concreto de esa tabla específica. que se ejecutan cuando ocurre una acción dentro de la base de datos. actualizar o borrar. Recordamos cual es su sintaxis: CREATE TRIGGER nombre ON tabla FOR [DELETE | INSERT | UPDATE] AS sentencias Las palabras reservadas DELETE. El bloque de sentencias permite prácticamente cualquier tipo de ellas dentro del lenguaje T-SQL. ya que un trigger no puede devolver datos al usuario. si por ejemplo se ejecuta una inserción. una actualización. no se podrá utilizar la sentencia select.

bien de forma directa. si queremos recuperar los datos de la tabla que estamos borrando. Desencadenadores recursivos: se permite la recursividad entre las llamadas a los triggers. un trigger puede llamar a su vez a otro.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Las tablas deleted e inserted Dentro de la definición de un trigger. veamos en detalle las restricciones que implica la definición de triggers: • • • • Un trigger sólo se puede aplicar a una tabla Aunque un trigger se defina dentro una sola base de datos. puede provocar la ejecución de otro trigger. cuya estructura es similar a la tabla donde se esta ejecutando el trigger. puede hacer referencia a objetos que se encuentran fuera de la misma La misma acción del desencadenador puede utilizarse para definir más de un trigger sobre la misma tabla La opción SET elegida dentro de la ejecución de un desencadenador. se cancelará la ejecución de los triggers. si a su vez vuelve a modificar otra tabla. es decir. los datos que van a ser añadidos o borrados. se ejecutarán ambos triggers cuando ocurra dicho evento sobre la tabla. se deberá ejecutar el siguiente código: SELECT * FROM deleted Código fuente 174 Tipos de desencadenadores SQL-Server permite la definición de varios tipos de triggers. es una copia de la tabla en la cual se van a insertar o borrar los datos. volverá a su estado previamente definido una vez concluya la ejecución del mismo 184 . es decir. Así. se provoca la llamada de este último que. si definimos un trigger para insert. por ejemplo. es decir. • • Limitaciones de los triggers Aunque ya se han comentado algunas de las limitaciones a la hora de programar triggers. La utilidad de estas dos tablas es la de realizar comprobaciones entre los datos antiguos y los nuevos. bien de forma indirecta. dentro del trigger. Desencadenadores anidados: si un trigger cambia una tabla en la que se encuentra definido otro trigger. y que contiene. y resulta que dicha tabla ya tenía definido un trigger para esa misma acción. precisamente. se pueden definir distintos triggers para la misma acción. y así sucesivamente. Si se supera el nivel de anidamiento permitido. podemos hacer referencia a un par de tablas lógicas. entre los cuales cabe destacar los siguientes: • Desencadenadores múltiples: para una misma tabla.

.xp_sendmail 'Pepe'. a. deberemos reescribir el trigger para las acciones update y delete.au_fname.au_id GO Código fuente 175 Ejemplos Veamos a continuación algunos ejemplos que complementen lo visto hasta ahora. DELETE AS SELECT a.au_lname.' GO Código fuente 176 Sin embargo.© Grupo EIDOS 21. CREATE TRIGGER trigger1 on authors FOR INSERT.. x. Por ejemplo. DROP TRIGGER enviar_correo GO CREATE TRIGGER enviar_correo ON Oferta FOR INSERT.au_id = x. como se muestra en el siguiente código. UPDATE.info FROM authors a INNER JOIN x ON a. que no existe en el momento de escribir el trigger. DELETE AS EXEC master.xp_sendmail 'Pepe'. si queremos que se envíe el mensaje cada vez que se cambia algo en la tabla de ofertas. cuando se añade una nueva oferta. UPDATE. Triggers en SQL – Server 2000 • • Así mismo. CREATE TRIGGER enviar_correo ON Oferta FOR INSERT AS EXEC master. 185 . el siguiente código hace referencia a una tabla x. muestra la forma de enviar un mensaje de correo electrónico a una persona. 'Tenemos una nueva oferta en nuestra base de datos. El siguiente código. no se permite la utilización de las sentencias del DDL dentro de la definición de un trigger En una vista no se puede utilizar un desencadenador Resolución diferida de nombres La resolución diferida de nombres es una utilidad que permite escribir triggers que hagan referencia a tablas que no existen en el momento de la compilación.

y se cancela la transacción con ROLLBACK TRANSACTION. y a continuación con la tabla de trabajos. utilizando la tabla inserted para comprobar los valores que se van a añadir o modificar. Para ello comprobamos esta situación mediante un if y. Ahora se comprueba si el trabajo que estamos asignando es el 1.'. que almacenarán los valores mínimo y máximo permitidos para un trabajo. 186 . que almacenará el nivel para el empleado. Todo esto sirve para encontrar los valores de la tabla de trabajos que corresponden al trabajo que vamos a asignar al empleado. se lanza un error con la sentencia RAISERROR. 1. 1) ROLLBACK TRANSACTION END ELSE IF NOT (@emp_lvl BETWEEN @min_lvl AND @max_lvl) BEGIN RAISERROR ('El nivel para el trabajo:%d debe estar entre %d y %d.emp_id JOIN jobs j ON j. A continuación realizamos un join entre la tabla de empleados y la tabla inserted o.job_lvl. @min_lvl.job_id = i. entre la antigua y la nueva). @max_lvl) ROLLBACK TRANSACTION END Código fuente 178 Primero declaramos las variables min_lvl y max_lvl.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS 'La tabla de ofertas ha cambiado' GO Código fuente 177 En el Código fuente 178. CREATE TRIGGER empleado_modificar ON employee FOR INSERT. @emp_lvl tinyint. y job_id que almacena el identificador del trabajo que se va a actualizar. entre la tabla de empleados tal y como está antes de ejecutar el trigger. lo que es lo mismo. @job_id smallint SELECT @min_lvl = min_lvl. 16. @job_id. y la tabla de empleados tal y como quedaría después de ejecutarlo (en otras palabras. si el nivel del trabajo no está dentro de los valores permitidos. @emp_lvl = i.job_id FROM employee e INNER JOIN inserted i ON e. en caso de que sea verdadero. @max_lvl tinyint. 16. emp_lvl. @max_lvl = max_lvl. @job_id = i. posibilite la cancelación de la acción.emp_id = i. en cuyo caso el valor para el nivel debería ser 10.job_id IF (@job_id = 1) and (@emp_lvl <> 10) BEGIN RAISERROR ('Debe especificar el nivel 10 para el trabajo 1'. se muestra como crear un trigger que. UPDATE AS /* Obtener el nivel para el trabajo actual */ DECLARE @min_lvl tinyint.

que cada %d que aparece dentro de la cadena de texto será sustituido respectivamente por el valor de cada una de las tres últimas variables que aparecen dentro de dicha sentencia. simplemente. Triggers en SQL – Server 2000 En otro caso se comprueba que el nivel de la tarea esté dentro de los límites permitidos para el empleado. Para los desconocedores del lenguaje C. 187 . Destacar.© Grupo EIDOS 21. y se cancelará la transacción. Si esto no se cumple se volverá a lanzar un error. quizá la última sentencia RAISERROR no les sea demasiado clara.

.

) que escapan a los objetivos del presente curso. como por ejemplo la destrucción de la base de datos. mientras que un usuario corriente sólo podrá . debido a aspectos físicos. El administrador del sistema actúa al nivel de superusuario. etc. en el que la principal división se establece entre el administrador del sistema y el resto de usuarios. Podemos hablar de seguridad a dos niveles: • Seguridad física: entendemos por seguridad física aquella que persigue salvaguardar los datos de agresiones externas. o parte de sus atributos. para la protección de la información. Seguridad lógica: la seguridad lógica afecta a la protección de los datos de accesos u operaciones no deseados. una consulta a información no autorizada por parte de un usuario. etc. como por ejemplo. sobre todo en entornos grandes.Seguridad Introducción El de la seguridad es un tema muy importante. Concesión de privilegios SQL Server mantiene un sistema de perfiles. ya que la seguridad física afecta a aspectos de administración (copias de seguridad. • En este capítulo nos centraremos en la seguridad lógica. mantenimientos de dispositivos duplicados con mirror. y puede realizar "casi" cualquier operación. el borrado de una tabla. donde la amenaza de potenciales accesos indebidos es muy grande. como por ejemplo un incendio o una inundación.

La sentencia que permite otorgar privilegios es la siguiente: GRANT sentencia TO usuarios Por ejemplo. . Del mismo modo se pueden establecer privilegios sobre los objetos. sino también en el ámbito de vista. o procedimientos almacenados. este control corresponde al administrador del sistema. si queremos otorgar el permiso de crear bases de datos y tablas al usuario Pepe. si otro usuario desea acceder a dicho objeto. esto es.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS realizar operaciones que afecten a sus objetos. deberemos escribir la sentencia que muestra Código fuente 179 GRANT CREATE DATABASE. Los permisos se pueden establecer en el ámbito de un usuario (conceder un privilegio a un usuario) o en el ámbito de grupo o público (accesible por todos). En este caso. No sólo se pueden conceder permisos en el ámbito de tabla. que normalmente suele ser el superusuario. GRANT SELECT ON authors TO PUBLIC Código fuente 181 190 . en lugar de sobre las acciones. actualización) sobre una serie de atributos de una tabla. o el usuario que lo haya creado. Por ejemplo. deberemos escribir la sentencia que aparece en el Código fuente 180. o a los objetos que le permita el administrador u otro usuario. En principio. los permisos pueden ser propagados en cascada. si deseamos que todos los usuarios puedan consultar la tabla de autores. no podrá hacerlo.. bases de datos. a menos que el propietario o el administrador le dé permiso. deberemos escribir lo que indica el Código fuente 181.) tienen un propietario. la sintaxis es la mostrada GRANT permisos (columnas) ON tabla TO usuario La sentencia GRANT permite establecer los permisos deseados (inserción. a unos determinados usuarios. Los objetos de SQL Server (tablas.. De todas maneras. para que éste a su vez pueda dar permiso a otros. CREATE TABLE TO Pepe Código fuente 179 Si queremos otorgar todos los permisos a todos los usuarios. Del mismo modo. GRANT ALL TO PUBLIC Código fuente 180 Cuidado con esta sentencia ya que es muy peligroso dejar que cualquier usuario haga lo que quiera. borrado. un usuario puede dar permiso a otro usuario.

Seguridad Con esto lo que hacemos es conceder el permiso SELECT sobre la tabla Authors. y que éste a su vez pueda conceder este privilegio a otros usuarios. UPDATE ON authors TO PUBLIC Código fuente 183 Si queremos propagar los privilegios. GRANT SELECT. deberemos ejecutar el Código fuente 182. GRANT SELECT (au_lname) ON authors TO PUBLIC Código fuente 182 Y si deseamos que además de consultar se pueda actualizar. Para revocar todos los permisos. debemos escribir la sentencia mostrada en el Código fuente 184. si queremos conceder el privilegio de ejecución de un procedimiento almacenado a un usuario. GRANT EXECUTE ON procedure TO usuario WITH GRANT OPTION Código fuente 184 Revocación de privilegios La sentencia homóloga a la concesión de privilegios es REVOKE. REVOKE CREATE DATABASE FROM alberto Código fuente 185 Estamos impidiendo al usuario alberto la posibilidad de crear bases de datos. y usuarios establece una lista de usuarios a los cuales se les aplicará dicha sentencia. a todos los usuarios. Por ejemplo. la sentencia en cuestión es la que muestra el Código fuente 183. deberemos especificar ALL como sentencia a aplicar. debemos adjuntar la opción WITH GRANT OPTION. Con esta sentencia podemos quitar permisos a los usuarios sobre un objeto. Por ejemplo. o para ejecutar ciertas sentencias. si ejecutamos el Código fuente 185. 191 .© Grupo EIDOS 22. Si queremos restringir el SELECT al campo au_lname. La sintaxis para quitar permisos sobre la ejecución de sentencias es la siguiente: REVOKE sentencia FROM usuarios donde sentencia especifica aquellas cuyos permisos se revocan.

y a todos los que éstos concedieron permisos. La opción CASCADE es opcional. la sentencia a ejecutar aparece en el Código fuente 189. a los usuarios especificados. éstos conservarán los suyos. au_fname) ON authors FROM Pepe Código fuente 189 Y si queremos revocar dicho permiso no sólo al usuario Pepe. REVOKE SELECT (au_lname. el Código fuente 186 revoca todos los permisos a todos los usuarios.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Así mismo. o tiene varios perfiles. es decir. REVOKE ALL FROM PUBLIC Código fuente 186 La sentencia para aplicar revocación de permisos a objetos aparece en el Código fuente 187. y permite revocar la propagación en cadena de permisos a usuarios. au_fname) ON authors FROM Pepe CASCADE Código fuente 190 192 . escribimos lo que indica el Código fuente 188. la opción papel permite eliminar la ambigüedad que se puede originar cuando un usuario pertenece a varios grupos. pero no podrán autorizar a terceros. REVOKE [GRANT OPTION FOR] permisos [(atributos)] ON tabla FROM usuarios [CASCADE] AS papel Código fuente 187 La opción GRANT OPTION FOR es opcional. Por ejemplo. ejecutaremos el Código fuente 190. REVOKE SELECT (au_lname. deberemos establecer public en la lista de usuarios. Por ejemplo. La opción permisos permite especificar los permisos que se revocarán. para que la sentencia tenga efecto para todos los usuarios de la base de datos. sino también a todos los usuarios a los que éste a otorgado dicho permiso. pudiendo restringirlos a una serie de atributos o a una o varias tablas. Por último. si queremos revocar los permisos de inserción de filas en la tabla autores. es decir. y permite revocar privilegios en cascada. REVOKE INSERT ON authors FROM Pepe Código fuente 188 Si no queremos que dicho usuario consulte los atributos au_lname y au_fname de dicha tabla. al usuario Pepe.

Pero el problema surge cuando el administrador del sistema se olvida de este detalle y. consiste en mantener vistas de la base de datos.© Grupo EIDOS 22. es decir la porción de la base de datos que es accesible a los usuarios. Una vista es un conjunto de información que es accesible por uno o varios usuarios. Para evitar que esto suceda. Puesto que una vista se puede contemplar como una consulta a una parte de la información. Corresponde al administrador en este caso el estudio de las consultas que se pueden realizar con relación a los usuarios del sistema. La sintaxis para denegar permisos es la siguiente: DENY sentencia TO usuarios Y para objetos: DENY permisos [(atributos)] ON tabla TO usuarios [CASCADE] El funcionamiento es similar al ya visto en las anteriores sentencias. bastará con revocarle el privilegio a hacerlo. tenemos un usuario de la base de datos un tanto conflictivo. mientras no se revoque dicha denegación. lo recomendable es denegar el permiso a dicho usuario. no se le podrán conceder privilegios para la creación de bases de datos a dicho usuario. El lector se preguntará ¿por qué una vista impide realizar accesos indebidos?. como por ejemplo a los atributos au_lname y au_fname de la tabla de autores. la respuesta es fácil. Si por ejemplo. lo que nos lleva a pensar que la base de datos puede mantener varias vistas a la vez. si queremos que un usuario no acceda a determinados datos. Como ya se vio en la parte anterior sobre diseño de bases de datos. por error. Lo que permite es que dichos usuarios no obtengan privilegios. le daremos vistas que no consulten dicha información. DENY SELECT (au_lname. y otorgar permisos sobre las vistas a éstos. y no queremos que cree bases de datos. Del mismo modo podemos actuar para denegarle el permiso de acceder a determinados campos de una tabla. También se dijo que podía haber más de un esquema externo. hasta que no se revoque dicha denegación. Seguridad Denegación de permisos Otra opción es la de denegar un permiso a uno o varios usuarios. le concede dicho permiso. au_fname) ON authors TO conflictivo Código fuente 192 Mantenimiento de vistas Otro método para controlar la seguridad y el acceso indebido a los datos almacenados. DENY CREATE DATABASE TO conflictivo Código fuente 191 De esta manera. Pues bien. La sintaxis del comando para la creación de vistas es la siguiente: 193 . las vistas se corresponden con el esquema externo de la base de datos.

ya que permite controlar mejor los usos indebidos de estas sentencias. Proporcionar a los usuarios procedimientos almacenados para la inserción. Establecer perfiles y grupos de usuarios. de forma jerárquica incluso. Usar triggers para evitar ciertas operaciones no deseadas. si queremos crear una vista sobre el atributo au_lname de la tabla authors. escribiendo la sentencia que muestra el Código fuente 194 SELECT * FROM autores Código fuente 194 Recomendaciones Por último. deberá ejecutar la vista. ya que permite establecer más fácilmente los niveles de seguridad. CREATE VIEW autores (au_lname) AS SELECT au_lname FROM authors Código fuente 193 Si un usuario quiere consultar ahora los autores de la base de datos. ocultar. mientras que la opción WITH CHECK OPTION permite hacer visibles las modificaciones realizadas tras la ejecución de la vista. que todo administrador que se precie debe tener en cuenta a la hora de implementar la seguridad de una base de datos: • • • • Proporcionar un único identificador a cada usuario.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS CREATE VIEW vista [(atributos)] [WITH ENCRYPTION] AS sentencia [WITH CHECK OPTION] La opción WITH ENCRYTION permite encriptar. actualización y/o borrado de filas. Por ejemplo. es decir. el código de la vista. existen una serie de recomendaciones. para de esta manera saber en todo momento quien está haciendo qué. escribimos el Código fuente 193. 194 .

desc_region Las relaciones que tenemos son las siguientes: • • ave-árbol: un ave puede anidar en varios tipos de árboles.Ejemplo práctico de implementación Introducción En este capítulo. observaciones árbol: cod_arbol. El problema en sí es mantener una base de datos de ornitología (ciencia que estudia las aves). árbol-región: un árbol puede ser autóctono de varias regiones. migratoria. clase. así como si es un ave migratoria o no. para recopilar los conocimientos aprendidos a lo largo del curso. nombre. y la región de la cual es autóctono. tipo_hoja región: cod_region. De cada clase de árbol. se desea conocer su nombre. y en un árbol pueden anidar varias especies (N-M). la clase a la que pertenece y el tipo de árbol en el que anida. estudiaremos un ejemplo. Por consiguiente. . tenemos las siguientes entidades: • • • ave: cod_ave. Se desea almacenar la información de cada una de las especies del país. el nombre científico. nom_cientifico. De cada especie se quiere conocer el nombre de la misma. nombre. y en una región puede haber distintas clases de árboles (N-M). el tipo de hoja.

al usar un SGBD concreto para la implementación. CREATE DATABASE ornitologia Código fuente 195 Una vez creada la base de datos. también engloba al diseño lógico específico. Lenguaje de definición de datos Lo primero que haremos será crear la base de datos. 196 . para obtener el esquema físico. a la que denominaremos ornitología. utilizaremos el Query Analizer de SQL Server. nos queda el esquema lógico que muestra la Figura 95. Lo que realizaremos es codificar las instrucciones necesarias en Transact SQL.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Con la anterior información. y las relaciones N-M generan también tabla. Destacar que lo que aquí entendemos por diseño físico. ya que en nuestro caso no se aplicarán métodos de normalización o particionamiento. Con esto. seleccionándola de la lista desplegable que aparece en la parte superior derecha del Query Analizer. Para implementar el esquema en Transact SQL. Cada entidad genera una tabla. podemos obtener el diagrama entidad-relación que vemos en la Figura 94. Figura 94 Una vez realizado el diseño conceptual. con las claves de ambas entidades como atributos. el siguiente paso es realizar el diseño lógico. con sus atributos. para lo cual escribimos el Código fuente 195. nos conectamos a ella. Figura 95 El siguiente paso en el diseño es realizar el diseño físico. cuya primera etapa es el paso a tablas.

cod_region smallint NOT NULL) Código fuente 199 Una vez creadas las tablas. es decir. migratoria bit) Código fuente 196 En la anterior sentencia cabe destacar que los atributos cod_ave y nombre han sido declarados como no nulos. clase varchar(10). es decir.© Grupo EIDOS 23. al que llamaremos clave. nombre varchar(30) NOT NULL. Empezaremos por crear un índice único que será la clave de la tabla ave. y un 1 si lo es. no se podrá insertar filas que no tengan valores nulos para dichos atributos. CREATE TABLE ave ( cod_ave smallint NOT NULL. tipo_hoja varchar(10)) Código fuente 197 Seguimos con la tabla de regiones. el siguiente paso es crear los índices para ellas. nom_cientifico varchar(30). CREATE TABLE region ( cod_region smallint NOT NULL. que son ave_arbol. desc_region varchar(30) NOT NULL) Código fuente 198 Y por último las tablas que las relacionan. se utilizará un campo bit. y que utilizará el campo cod_ave. Empezaremos por crear la tabla ave. cod_arbol smallint NOT NULL) CREATE TABLE arbol_region ( cod_arbol smallint NOT NULL. y arbol_region: CREATE TABLE ave_arbol ( cod_ave smallint NOT NULL. creamos la tabla arbol. un 0 para indicar que el ave no es migratoria. nombre varchar(30) NOT NULL. Para especificar si un ave es migratoria o no. Ejemplo práctico de implementación A continuación crearemos las tablas obtenidas en el esquema lógico. CREATE TABLE arbol ( cod_arbol smallint NOT NULL. Análogamente. 197 .

Pero eso no es problema.arbol_region. es labor del administrador el decidir a quien y sobre que objetos otorga qué permisos. para definir el esquema. ALTER TABLE ave ADD observaciones text NULL Código fuente 202 Por último. A continuación utilizaremos el Lenguaje de Manipulación de Datos para introducir información en el esquema. Nosotros. y para realizar algunas consultas. de momento. donde los índices de clave única serán por cod_arbol para la tabla arbol. ya que podemos modificar cómodamente el esquema de dicha tabla.cod_region) Código fuente 201 Oh. !vaya!. y por cod_ave y cod_arbol para la tabla ave_arbol: ALTER ALTER ALTER ALTER TABLE TABLE TABLE TABLE arbol ADD CONSTRAINT clave_ab PRIMARY KEY (cod_arbol) region ADD CONSTRAINT clave_re PRIMARY KEY (cod_region) ave_arbol ADD CONSTRAINT clave_aa PRIMARY KEY (cod_ave. Empezaremos añadiendo los siguientes datos: • Tabla ave Cod_ave Nombre 1 2 Flamenco Pato salvaje Nom_cientifico Clase Zancuda Migratoria Observaciones Si Migran en grupo hacia lugares cálidos Palmípedo No 198 . por cod_arbol y cod_region para la tabla. por cod_región para la tabla región. nos hemos olvidado de definir un atributo para la tabla ave. crearemos una vista para consultar todas las aves que son migratorias CREATE VIEW migratorias AS SELECT nombre FROM ave WHERE migratoria = 1 Código fuente 203 Lenguaje de manipulación de datos Hasta ahora hemos estado utilizando el Lenguaje de Definición de Datos. para introducir un nuevo campo. mediante la sentencia ALTER.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS ALTER TABLE ave ADD CONSTRAINT clave_av PRIMARY KEY (cod_ave) Código fuente 200 Análogamente hacemos con las demás tablas.cod_arbol) arbol_region ADD CONSTRAINT clave_ar PRIMARY KEY (cod_arbol.

nombre. clase. 1. 1. (1. 'Naranjo'. migratoria. 'Roble'. nombre. nombre. 'Golondrina común'. 'Mirlo Blanco'. nombre. 'Famosas por los versos de Becquer') Código fuente 204 • Tabla árbol Cod_arbol Nombre Tipo_hoja 1 2 3 4 Encina Roble Naranjo Pino Caduca Perenne Caduca Perenne Tabla 34 INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INTO arbol (cod_arbol. 1. 0) INSERT INTO ave (cod_ave.© Grupo EIDOS 23. migratoria) VALUES (2. 'Palmipedo'. 'Encina'. nombre. migratoria. (2. 'Pato salvaje'. 'Emite un sonido muy peculiar') INSERT INTO ave (cod_ave. 'Zancuda'. observaciones) VALUES (1. 'Caduca') INTO arbol (cod_arbol. migratoria. nom_cientifico. 'Migran en grupo hacia lugares cálidos') INSERT INTO ave (cod_ave. nombre. 'Flamenco'. observaciones) VALUES (4. 'Caduca') INTO arbol (cod_arbol. 'Golondrina'. 'Pino'. observaciones) VALUES (3. clase. nombre. 'Perenne') INTO arbol (cod_arbol. 'Perenne') tipo_hoja) tipo_hoja) tipo_hoja) tipo_hoja) Código fuente 205 199 . (4. nombre. (3. Ejemplo práctico de implementación 3 4 Mirlo Blanco Golondrina Golondrina común Tabla 33 Si Si Emite un sonido muy peculiar Famosas por los versos de Becquer INSERT INTO ave (cod_ave.

1) INTO arbol_region (1. sur y nor-noroeste y robles en la región centro. (5. cod_region) (cod_arbol. 1) INTO arbol_region (4. 'Nor-noroeste') INTO region (cod_region. cod_region) (cod_arbol. 'Sur') INTO region (cod_region. 1) (cod_arbol. cod_region) (cod_arbol. (3. 3) INTO arbol_region (2. cod_region) (cod_arbol. nor-noroeste y Pirineos. INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INTO arbol_region (4. con los valores correspondientes a cada código de arbol y región. encinas en las regiones centro. cod_region) (cod_arbol. 2) INTO arbol_region (1. 'Centro') INTO region (cod_region. 'Levante') desc_region) desc_region) desc_region) desc_region) desc_region) Código fuente 206 Supongamos ahora que nos dicen que puede haber pinos en las regiones centro.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS • Tabla región Cod_region Desc_region 1 2 3 4 5 Centro Sur Nor-noroeste Pirineos Levante Tabla 35 INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INSERT VALUES INTO region (cod_region. (4. 5) INTO arbol_region (1. cod_region) (cod_arbol. (1. Lo que tenemos que hacer es dar de alta estas filas en la tabla arbol_region. naranjos en la región Levante. 4) INTO arbol_region (3. (2. cod_region) Código fuente 207 200 . cod_region) (cod_arbol. 'Pirineos') INTO region (cod_region. 3) INTO arbol_region (4.

4) INSERT INTO ave_arbol (cod_ave. hacemos un join contra la tabla arbol_region.cod_region AND arbol_region.desc_region = 'centro' AND region. INSERT VALUES INSERT VALUES INTO ave_arbol (cod_ave. • El número de aves que son migratorias. 201 . Para ello. cambiaremos este ave por el mirlo común. UPDATE ave SET nombre = 'Mirlo común' WHERE nombre = 'Mirlo blanco' Código fuente 209 Supongamos ahora que queremos realizar las siguientes consultas. Con las filas obtenidas. deberemos realizar otro join contra la tabla árbol.cod_arbol Código fuente 210 Lo que hace la anterior sentencia es obtener el atributo desc_arbol de la tabla arbol. Ejemplo práctico de implementación Supongamos ahora que nos dicen que el mirlo blanco anida en los naranjos y en los pinos. arbol_region. cod_arbol) (3. 3) INTO ave_arbol (cod_ave. con la sentencia que aparece en el Código fuente 209. 1) Código fuente 208 Puesto que de momento no hemos encontrado ningún mirlo blanco. para obtener el código de los árboles cuya región es centro.© Grupo EIDOS 23.cod_arbol = arbol. El resultado obtenido son los árboles pino. Para ello deberemos contar todas las filas de la tabla ave. Para ello debemos actualizar la fila correspondiente. cuyas sentencias se especifican a continuación: • Todos los árboles de la región centro: SELECT nombre FROM arbol. cod_arbol) (3. encina y roble. Si ahora queremos obtener la descripción del árbol. y que los patos salvajes anidan en los estanques donde preferentemente haya encinas.cod_region = arbol_region. region WHERE region. cuyo atributo migratoria tenga el valor true. cod_arbol) VALUES (2. Lo que hay que hacer es crear las filas correspondientes a cada uno de los códigos en la tabla ave_arbol. primero se pone la condición de que la región debe ser centro.

tipo_hoja = 'caduca' AND arbol. • El nombre de las aves que anidan en árboles de hoja caduca ordenados alfabéticamente. con la tabla ave. Lo que debemos hacer es seleccionar primero todas las filas cuyo atributo tipo_hoja para luego hacer el join de estas filas con la tabla ave_arbol por el campo cod_arbol.nombre Código fuente 212 Como resultado del Código fuente 212. ave_arbol. para obtener así el código de las aves que anidan en dichos árboles.nombre FROM arbol.cod_ave = ave.cod_arbol AND ave_arbol. Acto seguido. SELECT ave. para hacerlo ejecutamos el Código fuente 213.cod_ave ORDER BY ave. por el atributo cod_ave y proyectar sobre nombre. deberemos realizar un join de las filas obtenidas. SELECT * FROM migratorias Código fuente 213 202 . podemos aprovechar la vista anterior. obtenemos que dichas aves corresponden al mirlo blanco y al pato salvaje Si ahora queremos consultar todas las aves que son migratorias. si queremos obtener el nombre de las aves. La anterior explicación se resume en la sentencia mostrada en el Código fuente 212.cod_arbol = ave_arbol.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS SELECT count(*) FROM ave WHERE migratoria = 1 Código fuente 211 El resultado obtenido es el de 3 aves. ave WHERE arbol.

. Sería algo del estilo “empresa – empleado – empresa . El primero nació como una conceptualización de la forma de entender las relaciones entre los objetos. . Sin embargo. la evolución siguió otra rama alternativa. en el cual ya no se tienen árboles. Como ya se ha comentado. lo cual dificulta ampliamente la definición y el manejo del esquema. Sin embargo. como consecuencia de una necesidad de simplificación de los primeros modelos que se usaron como base. Para que el lector lo comprenda mejor. A pesar de ello. los primeros modelos que surgieron fueron el jerárquico y el modelo en red. El modelo en red nació como una ampliación del modelo jerárquico. sino grafos.”. Las relaciones entre los objetos se establecían de una manera natural. el relacional.Presente y futuro de las bases de datos La evolución de las bases de datos en los últimos años. dando lugar a las denominadas bases de datos orientadas a objetos. Aunque fueron muchos los que apostaron por éstas. es decir. que permitía navegar entre ellos para obtener la información que se necesitaba. cuya simplicidad y potencia revolucionaron el mercado de las bases de datos.. el modelo relacional. dieron lugar a uno nuevo. ha permitido el afianzamiento de un modelo que se ha tomado como base de la práctica totalidad de los SGBD existentes en la actualidad. mediante referencias a los mismos. la evolución de estos modelos. una clasificación natural. era una especie de clasificación del modo “pais – comunidad – provincia – localidad” o “empresa – departamento – empleado”. la realidad es que en la actualidad su uso no supera el 5% de la cuota de mercado con respecto al modelo relacional. no ha sido sino hasta hace unos pocos años cuando este modelo vio la luz.

Una vez que se tiene el DW. se pueden aplicar procesos que permitan una obtención de información añadida. filtrado y proceso de los datos. tediosa y difícil. para evitar incoherencias. cabe imaginar. y que se prevé tenga un mayor impacto si cabe. que tendría el método alta(). Como su propio nombre indica. mediante herramientas específicas (OLAP. une a éste la funcionalidad que ofrece la orientación a objetos. Así nace el modelo objeto-relacional. es el data warehousing y el data mining. para obtener. Por ejemplo. este proceso.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Debido a lo anterior. lo cual desbarata prácticamente todo el proceso de normalización. duplicidades e información irrelevante. de tal manera que dicha información pueda ser utilizada más provechosamente. ROLAP. Tomando como base el relacional. que se ejecutaría cada vez que se da de alta un nuevo domicilio. clientes. no paran de surgir nuevos estudios y propuestas de modelos que amplían los ya existentes. joven. podemos encontrar bases de datos espaciales (para manejo de información en tres dimensiones).) información de una manera más útil. cuyos atributos pueden ser a su vez referencias a objetos. se puede tener el atributo domicilio que se puede descomponer en calle. Esta técnica es muy útil sobre todo en el ámbito del marketing y publicidad. Por ejemplo. Una de las técnicas más importantes de extracción de información es la denominada data minning o minería de datos (en lo sucesivo DM). de una forma más eficaz y eficiente. Además. una empresa que dispone de cantidades ingentes de información (empleados. etc. posibles clientes potenciales para una campaña comercial. es una tarea ardua. Surge entonces el SQL:1999 como lenguaje estándar para el acceso y definición de este tipo de esquemas. De esta forma se puede obtener. y puede no tener relación ninguna entre sí (cada departamento manejaría únicamente la información relevante al mismo). proveedores. Como el lector ya habrá podido comprobar. por ejemplo. En cambio. lo que más expectación esta suscitando actualmente. permite una mejor gestión de los mismos. por ejemplo. que son una especie de vistas con la información que interesa obtener. en estos modelos ni siquiera se cumple la 1FN. entre otras. se pueden utilizar los denominados data marts. Así por ejemplo. que en un principio es gestionada desde ámbitos distintos. 204 . compras). que debido al avance y mejora de los SGBD actuales. ventas. que aparece dispersa en el ámbito del negocio. De esta forma se tienen relaciones en forma de tablas. bases de datos fuzzy (o que manejan información imprecisa. o personalizar el tipo de información que un cliente puede recibir. Así por ejemplo. el concepto de data warehousing (en lo sucesivo DW) se refiere a la posibilidad de integrar toda esta información. en un futuro no muy lejano. y así un sinfín de posibilidades. además de incorporar sus propios métodos. Por otro lado. fueron muchos los que pensaron que no sería mala idea unir lo mejor de ambos modelos: el relacional y el orientado a objetos. para su mejor gestión. con la peculiaridad que el acceso se realiza en varias dimensiones de una forma más eficaz (por ejemplo las ventas por proveedores en cada región). Por data warehousing se entiende el almacenamiento masivo de los datos que gestiona una empresa. se necesitará un lenguaje especial para definir y manejar la información. y que ya disponen de su propio lenguaje). Pues bien. que no se encuentra de manera explícita. como puede imaginar el lector. como por ejemplo alto. caro. que implica una carga. consiste en la navegación a través de los datos para inferir conocimiento mediante técnicas de Inteligencia Artificial. y se resume en la Figura 96. Sin embargo. que no aparece de manera explícita en el mismo. provincia y localidad.

Presente y futuro de las bases de datos Figura 96 Ya existen en el mercado varios productos que soportan tanto el DW como el DM. Sin embargo. como resume la Figura 97. pero que se espera crezca positivamente en un futuro no muy lejano. debido a su elevado precio. hacen que todavía sea un mercado que no se encuentre al alcance de todo el mundo.© Grupo EIDOS 24. ofreciéndonos diversas posibilidades de las ya mencionadas. pero que. Figura 97 205 . SQL Server 2000 ya nos permite adentrarnos es este mundo.

.

etc. las relaciones entre éstas y su cardinalidad. El diseño físico El diseño conceptual permite establecer la definición de las tablas. Los tipos de archivos manejables por Power Designor son dos: . etc. sino que también se ofrece la posibilidad de generar un script (trozo de código) que es capaz de crear el esquema físico para una plataforma y un SGBD concreto. al esquema físico. Pues bien. Power Designor permite al usuario establecer el diseño de un esquema relacional.. de forma clara y sencilla. es decir. se puede decir que Power Designor es una herramienta CASE para el diseño de bases de datos. y realizar ingeniería inversa. En nuestro caso.Diseño conceptual con Power Designor Introducción Empezaremos dando respuesta a la pregunta "¿qué es Power Designor?". El diseño conceptual 2. Una herramienta CASE es aquella que permite al usuario la realización de unas determinadas tareas de forma fácil y precisa. como el paso del diseño conceptual al físico. Además nos permite pasar fácilmente del esquema conceptual. las claves. y en general todos los aspectos relacionados con esta fase de diseño. los atributos y sus tipos. con sólo conocer su esquema físico. obtener el esquema conceptual de una base de datos. Power Designor abarca dos de las tres grandes etapas del diseño de un esquema relacional: 1. la redundancia controlada de datos. mientras que el diseño físico comprende la definición de índices. evitándole tareas engorrosas. Y no solo esto.

y hacer click con el botón izquierdo del ratón en cualquier parte de la pantalla. se deberá pulsar el botón de creación de entidades. es decir. Una vez que tengamos creada la entidad. En ella se deberá teclear el nombre que le demos a la entidad. Creación de una entidad Para entrar en la aplicación. su nombre. se deberán definir sus propiedades. acceder al menú File-New. atributos y tipos. Extensión PDM: contiene la definición del esquema físico (Physical Data Model) Power Designor se compone de cuatro módulos: • • • • Data Architect: se encarga de la definición de los esquemas conceptual y físico. Para crear un nuevo esquema conceptual. Figura 98 Para crear una nueva entidad. ProcessAnalist: para realizar el diseño de procesos. claves de la entidad. etc. su apariencia se muestra en la Figura 98. Es en el que nos centraremos. Pulsando el botón Rules se podrán definir las Bussiness Rules o Reglas de Negocio.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS 1. un código que representará de manera unívoca a la entidad. las 208 . y se deberá especificar si la entidad generará tabla en el esquema físico. o hacer doble click sobre dicha entidad. es decir. MetaWorks: útil para el trabajo en red de varios diseñadores. ejecutar el módulo DataArchitect. Para ello tenemos dos formas: pulsar el botón de definición de entidades y hacer click izquierdo sobre la entidad. Comprende la etapa de diseño del ciclo de vida del software. Nos aparecerá una pantalla en blanco junto con una barra de herramientas. Extensión CDM: contiene la definición del esquema conceptual (Conceptual Data Model) 2. La pantalla que nos aparece se muestra en la Figura 99. Acto seguido nos sale una pantalla en blanco. es decir. diagramas de flujo de datos. AppModeler: para la modelación del esquema físico.

Diseño conceptual con Power Designor restricciones que determinar el comportamiento de las entidades y/o sus relaciones. Ej: el crédito de un cliente no puede superar el 20% de su compra.000 euros" o "un proveedor sólo puede atender a un cliente" son ejemplos de reglas de negocio. para hacerlo. y el tipo de ésta. será preciso pulsar el botón List.© Grupo EIDOS Apéndice A. especificar el nombre y el código de la regla. Definición: Especifican características o propiedades de un objeto en el sistema de información. La pantalla que nos permite definir las reglas de negocio es la que se muestra en la Figura 101. Ej: la suma total de los pedidos realizados por un cliente. • La pantalla para la asignación de reglas de negocio a una entidad aparece en la Figura 100 Para añadir una regla.. y nos aparecerá una lista con todas las reglas definidas. en la 209 . Hecho: Describen los hechos o forma de funcionar de la empresa.. Figura 99 Las reglas de negocio pueden ser de los siguientes tipos: • • • Validación: Especifican las restricciones que puede tener un valor en el esquema. habrá que pulsar el botón New. "Un cliente no puede pedir un crédito superior a 1. Fórmula: Definen los cálculos a realizar en el sistema de información.. Ej: un cliente puede realizar uno o más pedidos.. bastará con pulsar el Botón Add. Ej: un cliente es una persona identificada por su DNI y por su nombre. Si queremos introducir una nueva regla. Si todavía no se ha introducido ninguna. Pulsando el botón Define se visualizará la siguiente pantalla. En este apartado también se definen las reglas de integridad referencial.

dependiendo del tipo de regla que hayamos escogido. aunque la mayor desventaja es. lo que implica una ganancia de tiempo no tan drástica. Además se puede especificar si la expresión a evaluar se desea ejecutar en el cliente o en el servidor. sin duda. Figura 100 Figura 101 La principal ventaja de ejecutar una expresión en el servidor radica en la velocidad de ejecución de la misma. 210 . la probabilidad de cargar al servidor con demasiado trabajo.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS que podremos teclear la descripción de la regla o la formula aplicable.

código y tipo de dato. o 2. Pulsar el botón New e introducir el nombre. en la que podremos incluir nuevos atributos para dicha entidad.© Grupo EIDOS Apéndice A. cuyo aspecto se muestra en la siguiente figura.. para lo cual pulsamos el botón Atributtes. lo cual permitirá seleccionar un atributo de entre los ya existentes en el sistema de información. Diseño conceptual con Power Designor Figura 102 Volvemos a la pantalla de definición de entidades para determinar los atributos de la entidad. Se mostrará entonces una nueva ventana.. Para ello se dispone de dos opciones: 1. Figura 103 211 . Pulsar el botón Add.

000. entidades y otros. e introducir otro tipo de restricciones como son el caso de las mayúsculas o minúsculas en los caracteres. código y tipo de dato de éste. es donde se permite la definición de restricciones mas especificas.999. ese atributo será clave para dicha entidad.. En este caso se ha introducido un dominio para los números telefónicos. En la carpeta de Validation Rules (Figura 106). es decir. La segunda es el tipo de atributo. o no permitir la modificación del atributo. se podrá acceder a la pantalla que permite hacerlo. el rango de valores que puede tomar. Dentro de esta pantalla también se puede especificar el dominio de un atributo. simplemente es un valor que no tiene valor (valga la redundancia). Power Designor nos permite escoger entre una amplia gama de tipos de datos. en las definiciones de atributos. que variará entre 600. se deberá pulsar el botón New e introducir el nombre. es decir. Una es la posibilidad de determinar un atributo como identificador (identifier). 212 . Figura 104 Para incluir un nuevo dominio. o como obligatorio (mandatory) en cuyo caso dicho campo deberá tener siempre un valor no nulo. Se ha visto hasta ahora que en la mayoría de las pantallas aparecen dos botones (o carpetas) con los nombres Description y Annotation. En el caso de que no tengamos definido ningún dominio todavía. En la carpeta de Standard Parameters es donde se especificará el rango que tomará el atributo.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS De esta pantalla cabe destacar dos cosas.. La utilidad de ambos es la de disponer de un editor que permite la introducción de textos explicatorios y/o aclaratorios. La definición en si del dominio se establece al pulsar el botón Check en el que se mostrará una nueva pantalla. como la Figura 105. En nuestro caso se ha optado por la expresión ofrecida por defecto. Recuérdese que un valor nulo no es ni el cero ni el espacio en blanco..999 (para los fijos). Dichos atributos serán traducidos a los tipos específicos del SGBD con el que se vaya a trabajar (recordar que en la definición del esquema conceptual no se tiene por qué saber la implementación física que se va a realizar). introduciéndolos en la lista de la derecha. también se puede introducir directamente la lista de valores que puede tomar. Ésta tiene un aspecto muy parecido al de todas las pantallas de definición vistas hasta ahora. En la lista desplegable etiquetada como Domain se puede seleccionar el dominio que se va asignar a ese atributo.000 (para los móviles) y 999. pulsando el botón . que permite establecer las principales características del dominio. dejando al usuario la posibilidad de especificar su longitud y precisión.

Diseño conceptual con Power Designor Figura 105 Figura 106 Creación de relaciones Se hablará en este apartado de las relaciones entendidas como la "unión" o relación entre dos entidades. Acto seguido haremos click derecho con el ratón en la entidad origen y.© Grupo EIDOS Apéndice A. Para crear una relación entre dos entidades pulsaremos el botón de relación entre entidades de la paleta de herramientas. 213 .

Es decir. Figura 107 Una vez definida la relación. obteniendo algo parecido a la Figura 108. para obtener el cuadro de diálogo de definición de propiedades. En el sentido contrario.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS sin soltarlo. lo moveremos hasta la entidad destino. bajo 214 . cada ocurrencia de la entidad proveedor puede relacionarse con una (cardinalidad mínima) o varias (cardinalidad máxima) ocurrencias de la entidad cliente. Para determinar la cardinalidad mínima. bajo el nombre de Cardinality. se estará indicando que la cardinalidad máxima es muchos (o N). Para establecer la cardinalidad máxima. haremos doble click sobre la relación. Por ejemplo. podemos decir que un proveedor puede distribuir a uno o más clientes. estamos diciendo que la cardinalidad máxima será uno. mientras que si se selecciona la opción Many. se dispone de otros botones de selección. Figura 108 Es aquí donde se deberá establecer la cardinalidad máxima y mínima de la relación en ambos sentidos. Si escogemos la opción One. Nuevamente. se dispone de unos botones de selección. un cliente sólo puede abastecerse de un proveedor. La Figura 107 muestra la relación existente entre las entidades cliente y proveedor. lo que implica cardinalidad mínima y máxima uno. el siguiente paso es establecer la cardinalidad de la misma.

© Grupo EIDOS Apéndice A. La relación de herencia Otro tipo especial de relación es la relación de herencia. de las que heredarán las entidades automóvil con atributo num_puertas. que estas relaciones. modelo. precio y num_puertas. y a continuación pinchar en las demás relaciones llevándolas hasta el punto de unión. modelo. Ni que decir tiene. una relación de este tipo indica que depende de otra relación para su identificación. podemos tener tres entidades: automóvil con los atributos marca. Como ya se estudio en anteriores temas. 215 . sin saber a que pedido corresponde. modelo y precio. Para indicar una relación de este tipo. la entidad motocicleta con los atributos marca. heredan o importan los atributos de la entidad padre. las tres relaciones tienen tres atributos en común. El ejemplo se representa como indica la Figura 109. Figura 109 Para establecer una relación de herencia. modelo. ya que no se sabrá a que línea de pedido nos estamos refiriendo. se deberá escoger en la paleta el botón relación de herencia. en el cual podremos establecer las reglas de negocio. Un tipo especial de relación es la relación de dependencia. De esta forma se tendrá una relación vehículo con los atributos marca. y la entidad linea_pedido. Por ejemplo. además de disponer de otras dos carpetas para introducir cualquier descripción que se nos ocurra. Si por ejemplo se tiene la entidad pedido con los pedidos realizados por un cliente. esta última entidad tiene una relación de dependencia con aquella. Podemos aprovechar esta ventaja para definir una relación de herencia. motocicleta con atributo cilindrada y bicicleta con atributo num_cambios. precio y num_cambios. bastará con seleccionar la caja de selección denominada Is dependent. suponiendo que estas son características básicas de cualquier vehículo. mientras que si se escoge la opción Mandatory se obliga a que la cardinalidad mínima será uno. Nuevamente nos encontramos en esta ventana con el botón Rules. modelo y precio. Pero si nos damos cuenta. Diseño conceptual con Power Designor el nombre Existence. con los detalles de cada pedido. Consiste en la propiedad que tienen algunas entidades de heredar el comportamiento de otras. marca. pinchar en la relación padre. Si indicamos la opción Optional. precio y cilindrada y la entidad bicicleta con los atributos marca. quiere decir que la cardinalidad mínima es cero. seleccionar una relación. con atributos privados o específicos a cada una.

.

pulsaremos el botón OK y.PDM. En la segunda carpeta se nos da la opción de preservar ciertos cambios. sino que ésta está divida entre las fases de diseño conceptual y diseño físico. Automáticamente aparece una pantalla. será preciso generar el esquema físico y cambiarlo según nuestras pretensiones y/o necesidades. si queremos realizar un particionamiento vertical. Una vez que estemos seguros de haber dado las opciones correctas. como por ejemplo los gráficos. Por ejemplo. las etiquetas. En la carpeta Generation se nos sigue preguntando una serie de parámetros. Para generar el esquema físico a partir del conceptual. Por ejemplo. los tipos de datos del mismo. como la mostrada en la Figura 110. para determinar las restricciones del SGBD. sobre todo.Generate Physical Model o pulsar las teclas Ctrl-G. Justo debajo se nos preguntará por el nombre del fichero en el que se guardará el modelo físico. se puede seleccionar la opción de menú Dictionary . En la parte superior se especifica el SGBD específico sobre el cual se generará el esquema físico. Cabe destacar que Power Designor no da la posibilidad de realizar la fase intermedia de diseño lógico. También se puede decir si las reglas de actualización o de borrado se propagarán a todas las tablas o sólo a la que afecte.Diseño físico con Power Designor Paso del esquema conceptual al esquema físico Una vez realizado el diseño del esquema conceptual. con extensión . permite especificar el nombre de los índices primarios y ajenos (campos que son clave en otras entidades) que se generarán para cada tabla. etc. etc. tras un breve período de tiempo nos aparecerá un mensaje con el resultado de la generación. el siguiente paso es obtener el esquema físico. o las reglas de negocio. si algo ha . Esto es importante.

se deberá revisar nuevamente el esquema conceptual.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS fallado. en otro caso tendremos el correspondiente esquema físico. Figura 110 Modificación de las tablas Figura 111 218 .

etiquetas. En este caso ya podemos hablar de tablas. insertar y/o cambiar la definición uno o más atributos de las tablas. que estudiaremos a continuación en detalle. Recuérdese. conseguir una mayor eficiencia. A esta funcionalidad se accede pulsando el botón Extended. para de esta forma. La forma de hacerlo es similar a la pantalla mostrada en el anterior tema acerca de la definición de atributos. ante el cual aparece la Figura 112. En ella podemos especificar varias características. el valor inicial o por defecto del mismo. Columnas La edición de columnas consiste en borrar. del número de actualizaciones. etc. de la velocidad del hardware. teniendo en cuentas las necesidades del sistema. editor. sin 219 . es decir. Podemos empezar modificando las características de las tablas. cuyo cometido es el aumento de eficiencia a la hora de realizar las consultas.© Grupo EIDOS Apéndice B. podremos adecuarlo a nuestro gusto. Figura 112 Indices La definición de los índices de una tabla es otra de las características del diseño físico ya estudiadas. etc. como pueden ser la forma de visualización (lista desplegable. apareciéndonos la Figura 111. Diseño físico con Power Designor Una vez generado el esquema físico. salvo que en esta se puede determinar un atributo como clave ajena (atributo que es clave en otra tabla). De esta manera será preciso realizar un estudio detallado de las consultas que se realizarán a la base de datos. para lo que será necesario hacer doble click sobre una de ellas. cabeceras. y las restricciones del SGBD. de la concreción física de las entidades diseñadas en el esquema conceptual.. que permite la determinación de ciertas características correspondientes a los atributos de una tabla. etc. comentarios que se mostrarán a la hora de visualizarlos.). Otra funcionalidad que ofrece Power Designor es la definición de atributos extendidos.

Unique: índice único. que sirven para identificar una ocurrencia de una entidad en la base de datos. es preciso realizar un estudio detallado de las transacciones que se darán en la base de datos. teclearemos su nombre. Dicha pantalla tiene la apariencia de la Figura 113. Por lo tanto. Para acceder a la pantalla de definición de índices. Es el índice que se seguirá por defecto. y define los atributos que son clave en la tabla.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS embargo. se deberá pulsar el botón Indexes. Este es otro tipo de claves. En el botón Alternate Keys se pueden especificar claves alternativas o secundarias. la desventaja que supone el tener una tabla de índices demasiado extensa. a la hora de realizar actualizaciones. sus campos no pueden tener valores duplicados. Figura 113 Para definir un nuevo índice. que son clave en otra tabla. Cluster: índice cluster. Foreign key: es el índice que hace referencia a campos de la tabla. pulsaremos el botón New. Además se puede especificar la ordenación del índice. Para añadir campos a un índice. se pulsará el botón Add y se seleccionarán los atributos que se desean añadir. y especificaremos su tipo. de entre los siguientes: • • • • Primary key: índice por clave primaria. usado para recorrer los cluster de una base de datos (se remite al lector al capítulo de diseño físico). además de las primarias. es decir. 220 . que puede ser ascendente o descendente.

permite la modificación de ciertas características de éstos.) con las cuales se mostrarán las tablas. Este código es dependiente del SGBD. y cuyo aspecto es el mostrado en la Figura 114. Diseño físico con Power Designor Atributos extendidos Como ya se ha visto. y define la acción que tendrá lugar ante ciertos eventos. totalmente distinta a la mostrada anteriormente. pulsando el botón Extended. 221 . como por ejemplo.© Grupo EIDOS Apéndice B. al insertar una tupla en la base de datos. pero cuya finalidad es la misma: modificar el aspecto de visualización de estos atributos. trozos de código que se ejecutan cuando ocurre un determinado evento. tamaño. etc. es decir. Figura 114 Como se puede observar. pero nos permite establecer las fuentes (tipo de letra. Triggers Como su propio nombre indica. Sin embargo. La Figura 115 muestra un ejemplo de definición de trigger. ni valores iniciales. los triggers son disparadores. estilo. En esta funcionalidad. nos podemos encontrar con otra pantalla. ni nada por el estilo. se pueden determinar las acciones que tendrán lugar cuando ocurra un determinado evento. accesible mediante el botón Triggers. en ella no se pueden definir formas de visualización de los atributos. la funcionalidad que ofrece Power Designor sobre atributos extendidos.

accesible por un usuario. ya que ya se ha estudiado en el capítulo sobre diseño conceptual. y la query o consulta. que afecten a un determinado número de tablas. Creación de vistas Se entiende por vista. 222 . Para editarla. se agrupa todo un conjunto de funciones que define el rango de valores que puede tomar un determinado atributo. una porción de la base de datos. y todas las reglas que debe verificar una tabla. pulsaremos el botón cualquier punto de la pantalla. Recuérdese la definición de vista recogida en el capítulo de introducción. y a continuación pincharemos en Para definir una vista en Power Designor. y cuyo comportamiento es similar en el diseño físico. Si no queremos que un usuario acceda a una determinada tabla. pulsando el botón Query. y nos aparecerá una pantalla como la que aparece en la Figura 116. Una vista permite la introducción de un nivel de seguridad. se definirán consultas.Bases de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Figura 115 Restricciones Bajo el nombre restricción. La query se podrá definir mediante el lenguaje SQL. y cuyo conjunto correspondía a la definición del nivel externo de la base de datos. En ella podemos definir las tablas que implica. pulsando el botón con dicho nombre. Es decir. pulsando el botón Tables. simplemente se le ofrecerán vistas que no impliquen dicha tabla. No se ahondará más en este tema. Además se puede dar la opción de modificar el contenido de las tablas (opción Updatable) o simplemente consultar (opción Query Only). bastará con hacer doble click sobre ella. y cada una de ellas podrá ser accedida por uno o varios usuarios.

Diseño físico con Power Designor Figura 116 223 .© Grupo EIDOS Apéndice B.

.

Ejemplo de diseño con Power Designor Para irnos familiarizándonos con el uso de S-Designar. y creamos un nuevo modelo conceptual (. dirección. Por otra parte. El funcionamiento de Enterprise SL es el siguiente. vamos a tratar de resolver un planteamiento utilizando esta herramienta. descripción y existencias. dirección. Producto: código de producto. ciudad y provincia. nombre. A continuación empezamos a definir entidades: • • • • Proveedor: nos interesa saber su código de proveedor.CDM). Pedido: código de pedido. nombre. A su vez. Para ello abrimos la utilidad DataArchitect de S-Designar. Cliente: de que se desea conocer su código de cliente. Además desea conocer en todo momento la disponibilidad de productos en el almacén. apellidos. Enterprise SL es una empresa de venta al público. ciudad. desea simplificar el tema de la facturación. cada vez que las existencias son inferiores a las 10 unidades de cada producto. Lo primero realizar es un diseño del esquema conceptual. de cara a Hacienda. provincia y teléfono. Existen una serie de proveedores que abastecen a dicha empresa. quiere informatizar su sistema. NIF. Para ello desea tener almacenados todos los pedidos. Para ello nos ha encargado que diseñemos una base de datos que permita la introducción y recuperación eficiente de datos. de cara al euro y al año 2000. para realizar pedidos de forma automática. . CIF. Enterprise SL desea tener almacenados los datos de todos sus clientes.

Esto implica la creación de otras dos nuevas entidades: • • Provincia: código de provincia y descripción. Para quitar la selección se puede pulsar el botón flecha en la paleta. Para crear un nuevo atributo pulsamos el botón New y le damos un nombre (CIF). un código (que será también CIF) y un tipo de dato (tipo carácter de longitud 10. La definición completa es la mostrada en la Figura 117 Ahora se nos plantean dos opciones: 1.. Pulsamos el botón entidad en la paleta de componentes y acto seguido pulsamos seis veces en cualquier punto de la pantalla. o 2. A10). Así procederemos con el resto de atributos. o hacer click con el botón derecho del ratón. y acto seguido pulsamos el botón Attributes. Factura: IVA e importe en pesetas y euros. Etc. Cruz Tenerife. en la ventana que nos aparece teclearemos el nombre de la entidad (Proveedor). ya que evitará el tener diferentes definiciones para una misma ciudad (Ej. teniendo en cuenta que la clave de dicha entidad será el atributo cod_proveedor. Santa Cruz de Tenerife. Sta.: Sta. por lo que tacharemos la caja de selección correspondiente a Identifier de dicho atributo. Tipificar las ciudades y provincias. Empezaremos por la entidad proveedor.Base de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS • • Linea_pedido: código de la línea de pedido y cantidad. Ya tenemos creadas las seis entidades. Dejar que el usuario introduzca la ciudad y la provincia como texto libre. Nos decantaremos por esta última opción. El siguiente paso es definir los atributos de cada una de ellas. Cruz Trfe. Ciudad: código de ciudad y descripción. Empezamos creando las entidades. 226 .). Para ello hacemos doble click sobre cualquiera de las entidades y.

El atributo desc_provincia será un texto de 20 caracteres. y será de tipo numérico de dos dígitos.© Grupo EIDOS Apéndice C. En la Figura 118 mostraremos como quedaría la pantalla de definición de la entidad provincia. siguiendo el mismo proceso indicado anteriormente. Figura 119 227 . Figura 118 El atributo cod_provincia será la clave de la entidad. Ejemplo de diseño con Power Designor Por lo tanto creamos dos entidades más. La definición de la entidad ciudad queda como indica la Figura 119.

Figura 121 Hacemos lo mismo con la entidad linea_pedido. 228 . que es el atributo cod_cliente. y pasamos a ahora a hacerlo con cliente. Figura 120 Lo único a destacar aquí es la clave de la entidad. En la Figura 121 definimos los atributos de la entidad Pedido. y los atributos obligatorios que son Nombre y Apellidos.Base de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Seguimos definiendo entidades.

como se observa en la Figura 124 En esta última definición. Figura 123 Y concluimos definiendo la entidad factura. pulsamos el 229 .© Grupo EIDOS Apéndice C. ya que ello supone un desperdicio de memoria. Para crearla. cabe destacar que se ha optado por no almacenar el importe en euros en un nuevo campo.386. máxime cuando se sabe el cambio de pesetas a euros. Lo único que se deberá realizar para calcularlo será dividir el importe en pesetas por 166. Ejemplo de diseño con Power Designor Figura 122 También definimos la entidad producto. con lo que ya tenemos una regla de negocio para la entidad factura.

Base de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS botón Rules. para lo que pulsaremos el botón Add en la pantalla y escogeremos dicha regla. pulsamos el botón Define y tecleamos lo que muestra la Figura 125. 230 . sólo nos queda añadirla a la entidad. Para definirla. Le damos el nombre Pesetas_a_euros. y decimos que es de tipo Formula. y en la pantalla que nos aparece pulsamos List. Figura 124 Figura 125 Una vez definida.

© Grupo EIDOS Apéndice C. y un producto puede ser abastecido por varios proveedores: relación N-M. el siguiente paso es crear las relaciones entre ellas. La cardinalidad máxima es N y la mínima es 1. y a continuación uniremos ambas entidades. que debe quedar como la Figura 127. pulsaremos el botón de relación en la paleta de componentes. Haciendo doble click sobre la relación creada. obtenemos la pantalla de definición. Para crear una relación entre ambas entidades. Ejemplo de diseño con Power Designor Figura 126 Una vez definidas todas las entidades. Figura 127 231 . Podemos observar varias relaciones entre pares de entidades: • Un proveedor puede abastecer a la empresa de varios productos.

no se puede identificar una línea de pedido. Figura 128 • Un pedido puede tener muchas líneas de pedido. Además.Base de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS • Un cliente puede realizar muchos pedidos. Esto implica una relación 1-N. si no se sabe el pedido al que corresponde. pero una línea de pedido sólo puede corresponder a un pedido. es decir. Figura 129 232 . pero un pedido sólo puede ser realizado por un cliente. la relación en el sentido de linea_pedido es dependiente. y la ventana queda como la Figura 128.

Figura 131 233 . mientras que un producto puede estar en varias líneas de pedido.© Grupo EIDOS Apéndice C. Ejemplo de diseño con Power Designor • En una línea de pedido sólo puede haber un producto. sin embargo una factura sólo puede corresponder a un cliente. Figura 130 • Un cliente puede tener varias facturas.

Figura 132 • Una ciudad puede tener varios proveedores.Base de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS • Una provincia puede tener muchas ciudades. ya que no nos interesa tener almacenadas las ciudades sin proveedores. pero como mínimo una. pero un proveedor sólo puede pertenecer a una ciudad. y una ciudad sólo puede pertenecer a una provincia. La cardinalidad mínima es uno. Figura 133 234 .

podemos saber su provincia. Figura 134 Pues bien. Figura 135 235 . que queda como muestra la Figura 135. Ejemplo de diseño con Power Designor • Una ciudad puede tener varios clientes. ya que sabiendo la ciudad a la que pertenece el cliente. pero un cliente sólo puede pertenecer a una ciudad. en la Figura 134 como no se ha incluido una relación entre provincia y cliente. ya tenemos el esquema conceptual.© Grupo EIDOS Apéndice C. Obsérvese.

Pulsamos Ok. y que almacena los productos que han sido abastecidos por cada proveedor. Figura 137 236 . fruto de la relación N-M entre las entidades producto y proveedor. Las flechas representan las operaciones de join que hay que realizar para obtener la información de una tabla. Figura 136 En él podemos observar como se ha añadido una nueva relación. denominada RELATION_63.Base de datos con SQL Server 2000 – Transact SQL © Grupo EIDOS Una vez obtenido el esquema conceptual. Para ello pulsamos Ctrl-G y escogemos un SGBD. El esquema físico queda como aparece la Figura 136. por ejemplo Microsoft Access 95. el siguiente paso es obtener el esquema físico.

Básicamente. ya que en la siguiente parte se estudiará a fondo la sintaxis de lenguaje SQL. Le daremos el nombre de Proveedor-Producto. pulsamos el botón Columns. Crearemos ahora una vista. compruebe el stock que queda. Figura 138 No se preocupe demasiado si no entiende la anterior consulta. y añadiremos un nuevo atributo. para que la secretaria encargada de realizar los pedidos. ya que no queda muy estético. Para ello hacemos doble click en dicha entidad. que será la fecha en la que se ha realizado la venta. y establecemos una consulta SQL. lo que hace es recuperar todos los productos cuyo stock es menor de 10 unidades. y pinchamos en cualquier punto de la pantalla. Para ello pulsamos el botón vista en la paleta de componentes. hacemos doble click sobre ella.© Grupo EIDOS Apéndice C. Ejemplo de diseño con Power Designor Lo primero que realizaremos será cambiar el nombre de la relación RELATION_63. pulsamos el botón New. Para definirla. 237 . y tecleamos el nuevo atributo.

.

visítenos en: http://www. tutorías. Si quiere información más precisa de las nuevas técnicas de programación puede suscribirse gratuitamente a nuestra revista Algoritmo en: http://www.com.es .algoritmodigital. o tiene cualquier tipo de problema.com. envíelo a la dirección de correo electrónico lalibreriadigital@eidos.com. exámenes y un completo plan formativo con otros textos. No deje de visitar nuestra reviata Alquimia en http://www. © Grupo EIDOS http://www.Si quiere ver más textos en este formato.es. sugerencia. con un profesor a su disposición.eidos.es/alquimia donde podrá encontrar artículos sobre tecnologías de la sociedad del conocimiento.almagesto.lalibreriadigital. Este libro tiene soporte de formación virtual a través de Internet. Si quiere hacer algún comentario. Si desea inscribirse en alguno de nuestros cursos o más información visite nuestro campus virtual en: http://www.eidos.

Sign up to vote on this title
UsefulNot useful