Diferencia entre revisiones de «Plantilla:PHP/SQL»
(→Instrucción CREATE=) |
(→Sentencias DCL) |
||
Línea 90: | Línea 90: | ||
[[Archivo:ddl_t9.png]]<br /> | [[Archivo:ddl_t9.png]]<br /> | ||
<hr /> | <hr /> | ||
+ | |||
+ | {{MRM_Actividad|Title=Crear una base de datos| | ||
+ | Crea la base de datos dado el siguiente enunciado | ||
+ | Clientes ('''''DNI''''', nombre, dirección, edad (mayor de 18 años y menor de 65), sexo (H, M, N_A), por defecto N_A) | ||
+ | Facturas ('''''Número''''' , fecha (por defecto la fecha actual, importe total, cantidad_productos) | ||
+ | }} | ||
====Sentencias DCL==== | ====Sentencias DCL==== | ||
Línea 109: | Línea 115: | ||
:Desace todos los cambios en la base de datos desde la ultima transacción confirmada | :Desace todos los cambios en la base de datos desde la ultima transacción confirmada | ||
}} | }} | ||
+ | |||
====Sentencias DML==== | ====Sentencias DML==== | ||
<br /> | <br /> |
Revisión de 23:29 27 abr 2018
Contenido
SQL
SQL es un lenguaje de consultas estructuradas o Structured Query Language. Es un lenguaje de 4º generación donde el programador o usuario del lenguaje especifica lo qué quiere, pero no establece el procedimiento a seguir para conseguirlo, no dice cómo ha de hacer el sistema para conseguirlo
Lenguaje no procedural Vs lenguaje procedural)
| |
Dime todos los empleados de más de 45 años o SELECT * FROM empleados WHERE edad>45; Lenguaje procedural (tipo php o java) Abre la tabla empelados Lee desde el primer registro hasta el último (Bucle) Verifica si ese empleado tiene mas de 45 Si es así añádelo a la lista de resultado Muestra la lista de resultado
|
Lenguaje para gestionar bases de datos relacionales cuyas instrucciones o sentencias especifican lo qué se quiere, no cómo se va a realizar |
Lenguajes dentro de SQL
SQL no es, como su nombre indica, solamente un lenguaje de consultas, sino que proporciona todas las instrucciones necesarias para gestionar una base de datos.
SQL incorpora tres tipos de lenguajes: de Definición, de Control, de Manipulación.
Las instrucciones de SQL se conocen como sentencias, y todas se caracterizan por que empiezan por una palabra reservada que identifica a qué lenguaje de los tres que tiene SQL pertenece esa instrucción.
|
Sentencias DDL
CREATE DATABASE usuarios; CREATE TABLE usuario( password VARCHAR(200), nombre varchar2(40) );
DROP TABLE usuario;
ALTER TABLE usuarios ADD direccion VARCHAR(20); |
Instrucción CREATE
- Sintaxis de la instrucción
- Los nombres de las columnas son identificadores
- Tipos de datos para las columnas
- Especificación de Restricciones
- Definición de Restricciones
- Definición de Restricciones
- Restricción unique
- Restrición Foreign Key
- Restricción Ckeck
- Creacción de tabla como resultado de una consulta
Sentencias DCL
GRANT ALL ON DATABASE.* TO 'manuel'@'localhost' #Asigna todos los privilegios sobre las tablas #de la base de datos 'database' # al usuario 'manuel'
|
Sentencias DML
INSERT INTO usuarios (nombre, password) VALUES("manuel", "password_no_segura");
DELETE FROM usuarios WHERE nombre="manuel";
UPDATE usuarios SET nombre="alicia" WHERE nombre="manolo";
Es esta la sentencia estrella. Usando el álgebra relacional, permite recuperar un subconjunto de los datos de la base de datos. Esta sentencia devuelve un conjunto de tuplas devueltas por la consulta. Normalmente va a devolverlo como un objeto dependiendo del lenguaje. Dentro de esta sentencia, se pueden encontrar 5 cláusulas de las cuales solo las dos primeras son obligatorias. Simplemente por recordarlas, ya que son contenido del módulo de primero de Bases de datos. SELECT FROM WHERE GROUP BY HAVING (ORDER BY) |
- Having solo se usa como opción en el group by
- Order by es un criterio de ordenación y no se considera como cláusula propiamente dicho, por eso la he puesto entre paréntesis.