Curso de SQL

Las consultas de selecci�n se utilizan para indicar al motor de datos que devuelva informaci�n de las bases de datos, esta informaci�n es devuelta en forma de conjunto de registros que se pueden almacenar en un objeto recordset. Este conjunto de registros es modificable.

.�Consultas B�sicas

La sintaxis b�sica de una consulta de selecci�n es la siguiente:

SELECT Campos FROM Tabla;

En donde campos es la lista de campos que se deseen recuperar y tabla es el origen de los mismos, por ejemplo:

SELECT Nombre, Telefono FROM Clientes;

Esta consulta devuelve un recordset con el campo nombre y tel�fono de la tabla clientes.

.�Devolver Literales

En determinadas ocasiones nos puede interesar incluir una columna con un texto fijo en una consulta de selecci�n, por ejemplo, supongamos que tenemos una tabla de empleados y deseamos recuperar las tarifas semanales de los electricistas, podr�amos realizar la siguiente consulta:

SELECT
    Empleados.Nombre, 'Tarifa semanal: ', Empleados.TarifaHora * 40
FROM
    Empleados
WHERE
    Empleados.Cargo = 'Electricista'

.�Ordenar los Registros

Adicionalmente se puede especificar el orden en que se desean recuperar los registros de las tablas mediante la cla�sula ORDER BY Lista de Campos. En donde Lista de campos representa los campos a ordenar. Ejemplo:

SELECT CodigoPostal, Nombre, Telefono FROM Clientes ORDER BY Nombre;

Esta consulta devuelve los campos CodigoPostal, Nombre, Telefono de la tabla Clientes ordenados por el campo Nombre.

Se pueden ordenar los registros por mas de un campo, como por ejemplo:

SELECT CodigoPostal, Nombre, Telefono FROM Clientes ORDER BY 
CodigoPostal, Nombre;

Incluso se puede especificar el orden de los registros: ascendente mediante la cla�sula ASC (se toma este valor por defecto) � descendente (DESC).

SELECT CodigoPostal, Nombre, Telefono FROM Clientes ORDER BY 
CodigoPostal DESC , Nombre ASC;

.�Uso de Indices de las tablas

Si deseamos que la sentencia SQL utilice un �ndice para mostrar los resultados se puede utilizar la palabra reservada INDEX de la siguiente forma:

SELECT ... FROM Tabla (INDEX=Indice) ...

Normalmente los motores de las bases de datos deciden que indice se debe utilizar para la consulta, para ello utilizan criterios de rendimiento y sobre todo los campos de b�squeda especificados en la cl�usula WHERE. Si se desea forzar a no utilizar ning�n �ndice utilizaremos la siguiente sintaxis:

SELECT ... FROM Tabla (INDEX=0) ...

.�Consultas con Predicado

El predicado se incluye entre la cla�sula y el primer nombre del campo a recuperar, los posibles predicados son:

Predicado Descripci�n
ALL Devuelve todos los campos de la tabla
TOP Devuelve un determinado n�mero de registros de la tabla
DISTINCT Omite los registros cuyos campos seleccionados coincidan totalmente
DISTINCTROW Omite los registros duplicados basandose en la totalidad del registro y no s�lo en los campos seleccionados.

ALL

Si no se incluye ninguno de los predicados se asume ALL. El Motor de base de datos selecciona todos los registros que cumplen las condiciones de la instrucci�n SQL. No se conveniente abusar de este predicado ya que obligamos al motor de la base de datos a analizar la estructura de la tabla para averiguar los campos que contiene, es mucho m�s r�pido indicar el listado de campos deseados.

SELECT ALL FROM Empleados; 
SELECT * FROM Empleados;

TOP

Devuelve un cierto n�mero de registros que entran entre al principio o al final de un rango especificado por una cl�usula ORDER BY. Supongamos que queremos recuperar los nombres de los 25 primeros estudiantes del curso 1994:

SELECT TOP 25 Nombre, Apellido FROM Estudiantes ORDER BY Nota DESC;

Si no se incluye la cl�usula ORDER BY, la consulta devolver� un conjunto arbitrario de 25 registros de la tabla Estudiantes. El predicado TOP no elige entre valores iguales. En el ejemplo anterior, si la nota media n�mero 25 y la 26 son iguales, la consulta devolver� 26 registros. Se puede utilizar la palabra reservada PERCENT para devolver un cierto porcentaje de registros que caen al principio o al final de un rango especificado por la cl�usula ORDER BY. Supongamos que en lugar de los 25 primeros estudiantes deseamos el 10 por ciento del curso:

SELECT TOP 10 PERCENT Nombre, Apellido FROM Estudiantes 
ORDER BY Nota DESC;

El valor que va a continuaci�n de TOP debe ser un Integer sin signo. TOP no afecta a la posible actualizaci�n de la consulta.

DISTINCT

Omite los registros que contienen datos duplicados en los campos seleccionados. Para que los valores de cada campo listado en la instrucci�n SELECT se incluyan en la consulta deben ser �nicos.

Por ejemplo, varios empleados listados en la tabla Empleados pueden tener el mismo apellido. Si dos registros contienen L�pez en el campo Apellido, la siguiente instrucci�n SQL devuelve un �nico registro:

SELECT DISTINCT Apellido FROM Empleados;

Con otras palabras el predicado DISTINCT devuelve aquellos registros cuyos campos indicados en la cl�usula SELECT posean un contenido diferente. El resultado de una consulta que utiliza DISTINCT no es actualizable y no refleja los cambios subsiguientes realizados por otros usuarios.

DISTINCTROW

Este predicado no es compatible con ANSI. Que yo sepa a d�a de hoy s�lo funciona con ACCESS.

Devuelve los registros diferentes de una tabla; a diferencia del predicado anterior que s�lo se fijaba en el contenido de los campos seleccionados, �ste lo hace en el contenido del registro completo independientemente de los campo indicados en la cl�usula SELECT.

SELECT DISTINCTROW Apellido FROM Empleados;

Si la tabla empleados contiene dos registros: Antonio L�pez y Marta L�pez, el ejemplo del predicado DISTINCT devuleve un �nico registro con el valor L�pez en el campo Apellido ya que busca no duplicados en dicho campo. Este �ltimo ejemplo devuelve dos registros con el valor L�pez en el apellido ya que se buscan no duplicados en el registro completo.

.�Alias

En determinadas circunstancias es necesario asignar un nombre a alguna columna determinada de un conjunto devuelto, otras veces por simple capricho o por otras circunstancias. Para resolver todas ellas tenemos la palabra reservada AS que se encarga de asignar el nombre que deseamos a la columna deseada. Tomado como referencia el ejemplo anterior podemos hacer que la columna devuelta por la consulta, en lugar de llamarse apellido (igual que el campo devuelto) se llame Empleado. En este caso proceder�amos de la siguiente forma:

SELECT DISTINCTROW Apellido AS Empleado FROM Empleados;

AS no es una palabra reservada de ANSI, existen diferentes sistemas de asignar los alias en funci�n del motor de bases de datos. En ORACLE para asignar un alias a un campo hay que hacerlo de la siguiente forma:

SELECT Apellido AS "Empleado" FROM Empleados;

Tambi�n podemos asignar alias a las tablas dentro de la consulta de selecci�n, en esta caso hay que tener en cuenta que en todas las referencias que deseemos hacer a dicha tabla se ha de utilizar el alias en lugar del nombre. Esta t�cnica ser� de gran utilidad m�s adelante cuando se estudien las vinculaciones entre tablas. Por ejemplo:

SELECT Apellido AS Empleado FROM Empleados AS Trabajadores;

Para asignar alias a las tablas en ORACLE y SQL-SERVER los alias se asignan escribiendo el nombre de la tabla, dejando un espacio en blanco y escribiendo el Alias (se asignan dentro de la cl�usula FROM).

SELECT Trabajadores.Apellido AS Empleado FROM Empleados Trabajadores;

Esta nomenclatura [Tabla].[Campo] se debe utilizar cuando se est� recuperando un campo cuyo nombre se repite en varias de las tablas que se utilizan en la sentencia. No obstante cuando en la sentencia se emplean varias tablas es aconsejable utilizar esta nomenclatura para evitar el trabajo que supone al motor de datos averiguar en que tabla est� cada uno de los campos indicados en la cl�usula SELECT.

.�Recuperar Informaci�n de una base de Datos Externa

Para concluir este cap�tulo se debe hacer referencia a la recuperaci�n de registros de bases de datos externa. En ocasiones es necesario la recuperaci�n de informaci�n que se encuentra contenida en una tabla que no se encuentra en la base de datos que ejecutar� la consulta o que en ese momento no se encuentra abierta, esta situaci�n la podemos salvar con la palabra reservada IN de la siguiente forma:

SELECT DISTINCTROW Apellido AS Empleado FROM Empleados
IN 'c:\databases\gestion.mdb';

En donde c:\databases\gestion.mdb es la base de datos que contiene la tabla Empleados. Esta t�cnica es muy sencilla y com�n en bases de datos de tipo ACCESS en otros sistemas como SQL-SERVER u ORACLE, la cosa es m�s complicada la tener que existir relaciones de confianza entre los servidores o al ser necesaria la vinculaci�n entre las bases de datos. Este ejemplo recupera la informaci�n de una base de datos de SQL-SERVER ubicada en otro servidor (se da por supuesto que los servidores est�n lincados):

SELECT Apellido FROM Servidor1.BaseDatos1.dbo.Empleados

COMPARTE ESTE ARTÍCULO

COMPARTIR EN FACEBOOK
COMPARTIR EN TWITTER
COMPARTIR EN LINKEDIN
COMPARTIR EN WHATSAPP