Professional Documents
Culture Documents
En SQL los Alias estn definidos para ser utilizados tanto en Columnas como en Tablas. Bsicamente un Alias es utilizado para hacer que la Columna o Tabla involucrada en la consulta sea ms leble o entendible. Es decir, al usar un Alias se busca hacer del nombre de una Columna ms fcil de recordar o utilizar. Por ejemplo: Seleccionar el nombre de los estudiantes. Alias para Columnas: Select est_nombre Nombre From detalle_estudiantes En la consulta anterior la columna est_nombre recibe el Alias de Nombre por lo que al presentarse los resultados de la consulta, el nombre de la columna que aparecer no ser el original est_nombre sino el definido por el Alias, Nombre. Alias para Tablas: Select a.est_nombre From detalle_estudiantes a En la consulta anterior, para la tabla detalle_estudiantes se ha definido el Alias a, por lo que al seleccionar la columna est_nombre, debe definirse que sta pertenece a la tabla detalle_estudiantes, y para ello se utiliza a.est_nombre, es decir, Alias.columna_seleccionada. Tambin puede utilizarse la forma detalle_estudiantes.est_nombre, sin embargo es claramente ms prctico el hacer uso del Alias para as evitar el escribir el nombre completo de la tabla y slo referirnos a ella a travs de su Alias.
Los Principales usos del Alias son: Hay ms de una tabla involucrada en la consulta, por lo que utilizar la forma nombre_tabla.nombre_columna es menos prctico que usar alias.nombre_columna. Se estn utilizando funciones en la consulta. El nombre de la columna es demasiado largo o bien por su complejidad es irrecordable. Ms de una columna estn siendo combinadas.
Profesor Ayudante
Pgina 1
Cabe mencionar que los parmetros incluidos en un Procedimiento Almacenado varan dependiendo de cada procedimiento y lo que se busca de ste. Es decir, si la consulta SQL que se ejecutar en el procedimiento es del tipo INSERT INTO, los parmetros involucrados sern aquellos referidos a los datos que se buscan agregar a la base de datos. Si se trata de una consulta tipo UPDATE, los parmetros usados respondern a los datos de la base que se buscan actualizar o modificar. En el caso de un DELETE FROM, el o los parmetros utilizados sern los que condicionan la eliminacin de la base de datos. Mientras que cuando hablamos de una consulta tipo SELECT, el o los parmetros a utilizar sern aquellos que se utilizarn como referencia para la bsqueda y seleccin de datos de la base. Es decir, los parmetros corresponden a los datos que deben ser ingresados por el usuario para que la consulta sea realizada satisfactoriamente.
Profesor Ayudante
Pgina 2
Entendindose lo anterior, la consulta que da como a continuacin se muestra: Select a.cli_rut, a.cli_nombre, d.prod_nombre From Cliente a, Venta b, Detalle_Venta c, Producto d Where a.cli_rut = b.cli_rut and b.vent_idn =c.vent_idn and d.prod_idn = c.prod_idn and d.prod_nombre = nombre_producto and datepart (month, b.vent_fecha) = 8 group by a.cli_rut, a.cli_nombre, d.prod_nombre order by a.cli_nombre
Paso a Paso para llegar definir la consulta: Es recomendable partir definiendo las tablas involucradas en la consulta, no slo para el uso de Alias, sino tambin para las consultas en general, pues de esta manera se puede tener en vista desde el principio donde se encuentran los atributos que nos permitirn dar forma a la consulta. En este caso, tenemos que en el FROM de la consulta se definen las tablas y seguido de ello, encontramos el alias determinado para cada tabla. En este caso particular se utilizan las letras del alfabeto de la A a la D, mas esto no significa que el uso del Alias est restringido a esta frmula. Pueden utilizarse las letras iniciales del nombre de la tabla, palabras clave fcilmente relacionables a la tabla, etc. En trminos generales, el Alias es definido por el usuario para conseguir recordar fcilmente una tabla en especfico, por lo que depende del usuario el alias que se utilizar. Luego de determinar las tablas y los Alias a ser utilizados, se procede a determinar los atributos que sern seleccionados para llevar a cabo la consulta.
Profesor Ayudante
Pgina 3
Lo que responde al hecho de que lo que buscamos son clientes. Ahora viene la parte compleja de una consulta realizada sobre tablas que previamente contaban con una relacin n n y han sido normalizadas. En el WHERE de la consulta de deben definir TODAS las condiciones para que la consulta responda slo a lo que se busca responder, es decir, arroje el resultado correcto. Cuando la consulta es realizada sobre tablas con una antigua relacin n - n ya normalizada, se debe prestar atencin a que la clave principal de las tablas originales corresponda con la clave fornea de la tabla creada para normalizar. Esto tambin aplica para aquellas tablas involucradas en la consulta que presentan una relacin n 1 o 1 n. Es por esto que en la consulta que estamos utilizando como ejemplo se aprecia lo siguiente: a.cli_rut = b.cli_rut and b.vent_idn =c.vent_idn and d.prod_idn = c.prod_idn Lo que sin la aplicacin de Alias correspondera a lo siguiente cliente.cli_rut = venta.cli_rut and venta.vent_idn = detalle_venta.vent_idn and producto.prod_idn = detalle_venta.prod_idn Por tanto necesitamos que: o o o El cli_rut de la tabla Cliente sea igual al cli_rut de la tabla Venta, pues inicialmente buscamos clientes a los que se les haya vendido algn producto. El vent_idn de Venta sea igual al vent_idn de Detalle_Venta. Esto con el fin de verificar que en ambas anotaciones hablamos de la misma ocurrencia. El prod_idn de Producto sea igual al prod_idn de Detalle_Venta. Esto con el fin de verificar que en ambas anotaciones hablamos de la misma ocurrencia, es decir, el producto vendido sea el mismo que figura en los registros de productos de la empresa.
En lo que a condiciones originadas en el nmero de tablas involucradas se refiere, se entiende que si N es el nmero de tablas involucradas, N-1 es el nmero de condiciones mnimo a utilizar. Por lo tanto, debido que en esta consulta se han utilizado cuatro tablas, se han definido tres condiciones.
Profesor Ayudante
Pgina 4
Profesor Ayudante
Pgina 5
Profesor Ayudante
Pgina 6
Profesor Ayudante
Pgina 7