Está en la página 1de 26

DML

Data Manipulation Language (Lenguaje de manipulación de datos).


Modifica filas (registros) de la base de datos. Lo forman las
instrucciones INSERT, UPDATE, MERGE y DELETE.
Cláusulas.

• Son palabras especiales que permiten modificar el funcionamiento


de un comando (WHERE, ORDER BY,...)
• Operadores. Permiten crear expresiones complejas. Pueden ser
aritméticos (+,-,*,/,...) lógicos (>, <, !=,<>, AND, OR,...)
• Funciones. Para conseguir valores complejos (SUM(), DATE(),...)
Normas de escritura

• En SQL no se distingue entre mayúsculas y minúsculas.


• La instrucciones finalizan con el signo de punto y coma (;)
• Cualquier comando SQL (SELECT, INSERT,...) puede ser partidos
por espacios o saltos de línea antes de finalizar la instrucción
• Se pueden tabular líneas para facilitar la lectura si fuera necesario
DML
Introducción

• Es una de las partes fundamentales del lenguaje SQL. El DML (Data


Manipulation Language) lo forman las instrucciones capaces de
modificar los datos de las tablas. Al conjunto de instrucciones DML
que se ejecutan consecutivamente, se las llama transacciones y se
pueden anular todas ellas o aceptar, ya que una instrucción DML
no es realmente efectuada hasta que no se acepta (COMMIT). En
todas estas consultas, el único dato devuelto por Oracle es el
número de registros que se han modificado.
INSERT

• La adición de datos a una tabla se realiza mediante la instrucción


INSERT. Su sintaxis fundamental es:
• INSERT INTO tabla [(listaDeCampos)] VALUES (valor1 [,valor2 ...]);
• La tabla representa la tabla a la que queremos añadir el registro y
los valores que siguen a VALUES son los valores que damos a los
distintos campos del registro. Si no se especifica la lista de
campos, la lista de valores debe seguir el orden de las columnas
según fueron creados (es el orden de columnas según las devuelve
el comando DESCRIBE).
INSERT

• La lista de campos a rellenar se indica si no queremos rellenar


todos los campos. Los campos no rellenados explícitamente con la
orden INSERT, se rellenan con su valor por defecto (DEFAULT) o
bien con NULL si no se indicó valor alguno. Si algún campo tiene
restricción de obligatoriedad (NOT NULL), ocurrirá un error si no
rellenamos el campo con algún valor.
• Por ejemplo, supongamos que tenemos una tabla de clientes cuyos
campos son: dni, nombre, apellido1, apellido2, localidad y
dirección; supongamos que ese es el orden de creación de los
campos de esa tabla y que la localidad tiene como valor por
defecto Palencia y la dirección no tiene valor por defecto. En ese
caso estas dos instrucciones son equivalentes:
INSERT

• INSERT INTO clientes VALUES( '11111111','Pedro','Gutiérrez',


'Crespo',DEFAULT,NULL);

• INSERT INTO clientes(dni,nombre,apellido1,apellido2)


VALUES('11111111','Pedro','Gutiérrez', 'Crespo');

• Son equivalentes puesto que en la segunda instrucción los campos no


indicados se rellenan con su valor por defecto y la dirección no tiene
valor por defecto. La palabra DEFAULT fuerza a utilizar ese valor por
defecto.
UPDATE

• La modificación de los datos de los registros lo implementa la


instrucción UPDATE. Sintaxis:

• UPDATE tabla SET columna1=valor1 [,columna2=valor2...]


[WHERE condición]
UPDATE

• Se modifican las columnas indicadas en el apartado SET con los


valores indicados. La cláusula WHERE permite especificar qué
registros serán modificados. Ejemplos:

• UPDATE clientes SET provincia='Ourense' WHERE provincia='Orense';

• UPDATE productos SET precio=precio*1.16;

• El primer dato actualiza la provincia de los clientes de Orense para


que aparezca como Ourense.
• El segundo UPDATE incrementa los precios en un 16%.
Condición (WHERE)

• En la condición se pueden utilizar cualquiera de los siguientes


operadores de comparación:
DELETE

• Elimina registros de una tabloa, deben tener presente la


integridad referencial; se realiza mediante la instriccion DELETE.

• DELETE [FROM] tabla [WHERE condición] ;

• OJO…..
• Tener cuidado con el Where, los datos eliminados eliminados se
quedan.
DELETE

• Es más sencilla que las anteriores, elimina los registros de la tabla


que cumplan la condición indicada. Ejemplo:

• DELETE FROM empleados WHERE seccion=23;


DELETE

• Hay que tener en cuenta que el borrado


de un registro nos puede provocar fallos
de integridad y que la opción de
integridad ON DELETE CASCADE hace que
no sólo se borren los registros indicados
en el SELECT, sino todos los relacionados.
SELECT

• Las consultas de selección (Select) 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.
SELECT 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.
SELECT 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.
SELECT Ordenar los registros

• 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;
SELECT Predicados

• 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

Omite los registros cuyos campos seleccionados coincidan


DISTINCT
totalmente

Omite los registros duplicados basandose en la totalidad


DISTINCROW
del registro y no sólo en los campos seleccionados.
SELECT Predicados 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;


SELECT Predicados 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.
SELECT Predicados TOP

• 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.
SELECT Predicados 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.
SELECT Predicados DISTINCTROW
• 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.
SELECT 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;


SELECT Diagrama Resumen
Gracias….

También podría gustarte