Componentes Del SQL
Componentes Del SQL
Comandos
Existen tres tipos de comandos SQL:
Los DLL(Data Definition Language) que permiten crear y definir
nuevas bases de datos, campos e índices. Los DML(Data
Manipulation Language) que permiten generar consultas para
ordenar, filtrar y extraer datos de la base de datos. Los DCL(Data
Control Language) que se encargan de definir las permisos sobre los
datos
Lenguaje de definición de datos (DDL)
Comando Descripción
ALTER Utilizado para modificar las tablas agregando campos o cambiando la definición de los ca
ALTER
Este comando permite modificar la estructura de un objeto. Se pueden
agregar/quitar campos a una tabla, modificar el tipo de un campo,
agregar/quitar índices a una tabla, modificar un trigger, etc.
Ejemplo (agregar columna a una tabla):
DROP
Este comando elimina un objeto de la base de datos. Puede ser una
tabla, vista, índice, trigger, función, procedimiento o cualquier otro
objeto que el motor de la base de datos soporte. Se puede combinar con
la sentencia ALTER.
Ejemplo:
TRUNCATE
Este comando trunca todo el contenido de una tabla. La ventaja sobre
el comando DROP, es que si se quiere borrar todo el contenido de la
tabla, es mucho más rápido, especialmente si la tabla es muy grande.
La desventaja es que TRUNCATE sólo sirve cuando se quiere eliminar
absolutamente todos los registros, ya que no se permite la cláusula
WHERE. Si bien, en un principio, esta sentencia parecería ser DML
(Lenguaje de Manipulación de Datos), es en realidad una DDL, ya que
internamente, el comando TRUNCATE borra la tabla y la vuelve a crear
y no ejecuta ninguna transacción.
Ejemplo:
SELECT Utilizado para consultar registros de la base de datos que satisfagan un criterio determinado
INSERT Utilizado para cargar lotes de datos en la base de datos en una única operación.
UPDATE Utilizado para modificar los valores de los campos y registros especificados Utilizado para modi
definición de los campos.
Definición
Un lenguaje de manipulación de datos (Data Manipulation Language, o
DML en inglés) es un lenguaje proporcionado por el sistema de gestión
de base de datos que permite a los usuarios llevar a cabo las tareas de
consulta o manipulación de los datos, organizados por el modelo de
datos adecuado. El lenguaje de manipulación de datos más popular hoy
día es SQL, usado para recuperar y manipular datos en una base de
datos relacional.
INSERT
Una sentencia INSERT de SQL agrega uno o más registros a una (y sólo
una) tabla en una base de datos relacional.
Forma básica:
UPDATE
Una sentencia UPDATE de SQL es utilizada para modificar los valores
de un conjunto de registros existentes en una tabla.
Ejemplo:
DELETE
Una sentencia DELETE de SQL borra uno o más registros existentes en
una tabla.
Forma básica:
Ejemplo:
Clausulas
Las cláusulas son condiciones de modificación utilizadas para definir
los datos que desea seleccionar o manipular.
Comando Descripción
FROM Utilizada para especificar la tabla de la cual se van a seleccionar los registros
GROUP BY Utilizada para separar los registros seleccionados en grupos específicos
HAVING Utilizada para expresar condición que debe satisfacer cada grupo
ORDER BY Utilizada para ordenar los registros seleccionados de acuerdo con un orden específico
Operadores
Operadores Lógicos
Operador Uso
AND Es el “y” lógico. Evalúa dos condiciones y devuelve un valor de verdad sólo si ambas son
OR Es el “o” lógico. Evalúa dos condiciones y devuelve un valor de verdad si alguna de las do
Operadores de comparación
Operador Uso
BETWEEN Intervalo
LIKE Comparación
In Especificar
Funciones de agregado
Las funciones de agregado se usan dentro de una cláusula SELECT en
grupos de registros para devolver un único valor que se aplica a un
grupo de registros.
Comando Descripción
SUM Utilizada para devolver la suma de todos los valores de un campo determinado
Consultas
Consultas de selección
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. Este conjunto de registros
es modificable.
Básicas
La sintaxis básica de una consulta de selección es:
Criterios de selección
Operadores Lógicos
Los operadores lógicos soportados por SQL son:
AND, OR, XOR, Eqv, Imp, Is y Not.
# SELECT * FROM Empleados WHERE Edad > 25 AND Edad < 50;
# SELECT * FROM Empleados WHERE (Edad > 25 AND Edad < 50) OR
Sueldo = 100;
# SELECT * FROM Empleados WHERE NOT Estado = 'Soltero';
# SELECT * FROM Empleados WHERE (Sueldo > 100 AND Sueldo < 500) OR
(Provincia = 'Madrid' AND Estado = 'Casado');
Operador BETWEEN
Para indicar que deseamos recuperar los registros según el intervalo de
valores de un campo emplearemos el operador Between:
# SELECT * FROM Pedidos WHERE CodPostal Between 28000 And 28999;
(Devuelve los pedidos realizados en la provincia de Madrid)
Operador LIKE
Se utiliza para comparar una expresión de cadena con un modelo en
una expresión SQL. Su sintaxis es:
Operador IN
Este operador devuelve aquellos registros cuyo campo indicado
coincide con alguno de los indicados en una lista. Su sintaxis es:
Clausula WHERE
La cláusula WHERE puede usarse para determinar qué registros de las
tablas enumeradas en la cláusula FROM aparecerán en los resultados
de la instrucción SELECT. WHERE es opcional, pero cuando aparece
debe ir a continuación de FROM:
Avg(expr)
MAX, MIN
Devuelven el mínimo o el máximo de un conjunto de valores
contenidos en un campo especifico de una consulta. Su sintaxis es:
Min(expr)
Max(expr)
Un ejemplo de su uso:
SUM
Devuelve la suma del conjunto de valores contenido en un campo
especifico de una consulta. Su sintaxis es:
Sum(expr)
Por ejemplo:
# SELECT Sum(PrecioUnidad * Cantidad)
AS Total FROM DetallePedido;
GROUP BY
Combina los registros con valores idénticos, en la lista de campos
especificados, en un único registro:
1. Tabla clientes
2. +------+--------+----------+
3. | cid | nombre | telefono |
4. +------+--------+----------+
5. | 1 | jose | 111 |
6. | 2 | maria | 222 |
7. | 3 | manuel | 333 |
8. | 4 | jesus | 4444 |
9. +------+--------+----------+
resultando:
+--------+----------+--------+----------+
| nombre | telefono | accion | cantidad |
+--------+----------+--------+----------+
| maria | 222 | REDHAT | 10 |
| jesus | 4444 | NOVELL | 20 |
| jesus | 4444 | SUN | 30 |
+--------+----------+--------+----------+
LEFT JOIN
La sentencia LEFT JOIN nos dará el resultado anterior mas los campos
de la tabla de la izquierda del JOIN que no tienen coincidencias en la
tabla de la derecha:
con resultado:
+--------+----------+--------+----------+
| nombre | telefono | accion | cantidad |
+--------+----------+--------+----------+
| jose | 111 | NULL | NULL |
| maria | 222 | REDHAT | 10 |
| manuel | 333 | NULL | NULL |
| jesus | 4444 | NOVELL | 20 |
| jesus | 4444 | SUN | 30 |
+--------+----------+--------+----------+
RIGHT JOIN
Identico funcionamiento que en el caso anterior pero con la tabla que
se incluye en la consulta a la derecha del JOIN:
que mostrará:
+--------+----------+--------+----------+
| nombre | telefono | accion | cantidad |
+--------+----------+--------+----------+
| jose | 111 | NULL | NULL |
| manuel | 333 | NULL | NULL |
| NULL | NULL | FORD | 100 |
+--------+----------+--------+----------+
Vistas
Las vistas (“views”) en SQL son un mecanismo que permite generar un
resultado a partir de una consulta (query) almacenado, y ejecutar
nuevas consultas sobre este resultado como si fuera una tabla normal.
Las vistas tienen la misma estructura que una tabla: filas y columnas.
La única diferencia es que sólo se almacena de ellas la definición, no los
datos.
La cláusula CREATE VIEW permite la creación de vistas. La cláusula
asigna un nombre a la vista y permite especificar la consulta que la
define. Su sintaxis es:
SENTENCIA DESCRIPCIÓN