Bdii 04 SQL
Bdii 04 SQL
BASE DE DATOS II
SQL- Breve Historia
SQL (Structured Query Language) es el lenguaje relacional de
Base de Datos utilizado para trabajar con Bases de Datos
Relacionales, y su historia está íntimamente ligada al
desarrollo de éstas
La mayoría de las DBMSs relacionales comerciales poseen un
lenguaje declarativo de alto nivel, en el cual el usuario
especifica qué quiere como resultado, dejando las decisiones
de cómo ejecutar la consulta para el Sistema
Entre esos lenguajes, el más conocido es el SQL, que se volvió
el padrón norteamericano (ANSI 1986) e internacional (ISO
1989) para los DBMSs relacionales
Originalmente, al SQL se lo llamó SEQUEL (Structured English
QUEry Language) y fue proyectada e implementada en una
DBMS experimental de IBM conocida como System R, que fue
el prototipo de los RDBMSs comerciales de IBM: SQL/DS y DB2
Actualmente, todos los RDBMS proveen de una variación del
lenguaje SQL adaptado en mayor o menor grado a los
estándares mencionados
2
Resumen de Componentes
SQL
Lenguaje de Definición de datos (Data
Definition Language o DDL): proporciona
órdenes para la definición de esquemas de la
tabla, borrado de tablas, creación de índices y
modificación de esquemas de la tabla
3
Comandos SQL
Manipulación de Datos: Data
Manipulation Language (DML)
◦ SELECT, INSERT, UPDATE, DELETE, MERGE
Definición de Datos: Data Definition
Language (DDL)
◦ CREATE, ALTER, DROP, RENAME,
TRUNCATE
Control de Transacciones
◦ COMMIT, ROLLBACK, SAVEPOINT
Control de Acceso a los Datos: Data
control language (DCL)
◦ GRANT, REVOKE
4
Modelo Utilizado para los ejercicios
5
Introducción al SQL: La sentencia
básica
SELECT * | {[DISTINCT],columna |
expresión [alias],....}
FROM tabla;
6
Comandos SQL
Los comandos pueden tener varias
líneas
Se puede indentar para facilitar el
entendimiento
Los comandos pueden escribirse en
mayúscula o minúscula
Los comandos se ejecutan una vez
ingresados el en buffer
7
Para seleccionar todas las
columnas y filas
SQL> SELECT *
2 FROM b_areas;
8
Principales Tipos de Datos Incorporados
VARCHAR2(tamaño) Cadena de caracteres de longitud variable. El tamaño máximo es de 4.000 bytes y
mínimo de 1. (A partir de Oracle 12c este tipo de datos pueden almacenar ahora 32.767
bytes contra 4.000 bytes en la versión 11g).
NVARCHAR2(tamaño) Cadena de caracteres UNICODE de longitud variable. El tamaño máximo está
determinado por la definición del juego de caracteres nacional, con un límite máximo
de 4000 bytesbytes y mínimo de 1. (A partir de Oracle 12c este tipo de datos pueden
almacenar ahora 32.767 bytes contra 4.000 bytes en la versión 11g).
NUMBER(p,s) Numérico con ‘p’ posicions y escala ‘s’. La precisión ‘p’ varía de 1 a 38. La escala de -
84 a 127. Un valor numérico requiere 1 a 22 bytes.
LONG Datos de caracteres. Longitud de hasta 2 GB. Permanece para compatibilidad con
versiones anteriores de Oracle.
DATE Fecha. Desde el 1 de Enero de 4721 AC al 31 de Diciembre de 9999 DC. l formato por
defecto se determina explícitamente por el parámetro NLS_DATE_FORMAT. El tamaño
es de 7 bytes. Este tipo de datos contiene los campos de fecha y hora AÑO, MES, día,
hora, minuto y segundo.
TIMESTAMP (precisión Fecha en años, meses, días, minutos, segundos. La precisión es el número de dígitos
de fracción de seg.) de la parte fraccional de segundos (0 a 9 y por defecto 6). El formato por defecto se
determina explícitamente por el parámetro NLS_TIMESTAMP_FORMAT. El tamaño es
de 7 o 11 bytes, dependiendo de la precisión.
CHAR(tamaño) Representa caracteres de longitud fija. El tamaño máximo es de 2.000 bytes y mínimo
1.
BLOB Binary Large Object (Objeto grande binario). El tamaño máximo es de (4 gigabytes - 1)
* (tamaño del bloque de la base de datos).
CLOB Objeto grande de caracteres. El tamaño máximo es de (4 gigabytes - 1) * (tamaño del
bloque de la base de datos)
BFILE Contiene la localización de un archivo binario almacenado fuera de la base de datos.
Tamaño máximo de 4GB
9
Otros Tipos de Datos
TIMESTAMP [(precisión Tiene las mismas características que el TIMESTAMP, pero el el tamaño se fija en 13
de fracción de bytes, ya que este tipo de datos contiene los campos de fecha y hora: AÑO, MES, DIA,
HORA, MINUTO, SEGUNDO, TIMEZONE_HOUR y TIMEZONE_MINUTE. Cuenta con
seg.)] WITH TIME ZONE
las fracciones de segundo y una zona horaria explícita.
INTERVAL YEAR [(precisi Almacena un período de tiempo en años y meses, donde precisión del año es el número
ón del año)] TO MONTH de dígitos en el campo datetime AÑO. Los valores aceptados son del 0 al 9. El valor
predeterminado es 2. El tamaño se fija en 5 bytes.
INTERVAL YEAR usa el símbolo ‘-’ (guión), entre el año y el mes.
INTERVAL DAY Almacena un período de tiempo en días, horas, minutos y segundos, donde
[(precisión de días)] TO
SECOND [(fracción de * day_precision es el número máximo de dígitos en el campo datetime DÍA. Los valores
segundos)] aceptados son del 0 al 9. El valor predeterminado es 2.
* fractional_seconds_precision es el número de dígitos en la parte fraccionaria del
campo SEGUNDO. Los valores aceptados son del 0 al 9. El valor por defecto es 6.
El tamaño se fija en 11 bytes.
Este tipo de intérvalo utiliza espacio entre el número de días y la hora.
10
Expresiones Aritméticas
Operadores utilizados
• Add +
• Subtract -
• Multiply *
• Divide /
11
Expresiones Aritméticas
Ejemplo: Ver el importe total de cada detalle de ventas
12
Precedencia de Operadores
Multiplicación y división tienen precedencia por sobre resta y
suma
Los operadores se evalúan de derecha a izquierda
Los paréntesis ayudan a cambiar el orden de precedencia
Orden de Operaciones
precedencia
1 Operadores aritméticos
2 Operadores de Concatenación
3 Operadores de Condición
6 NOT EQUAL TO
9 OR <condición lógica>
13
Precedencia de Operadores
SQL> SELECT precio, precio * cantidad + 100
2 FROM b_detalle_ventas;
PRECIO PRECIO*CANTIDAD+100
---------- -------------------
208182 2081920
499091 4991010
PRECIO PRECIO*(CANTIDAD+100)
---------- ---------------------
208182 22900020
499091 54900010
14
Utilización de un “alias” para las columnas
La operación de “renombramiento” se da a través de la
utilización de un alias o sobrenombre, que aparece en la
cabecera de las columnas al seleccionarlas
• Es útil cuando la columna es el resultado de un cálculo
• Debe seguir inmediatamente a la columna u operación
que representará una columna
• Se puede utilizar la palabra clave “AS”, pero no es
obligatoria
• Si el alias tiene caracteres especiales o espacios, deberá
utilizarse comillas
PRECIO IMPORTE
---------- ----------
208182 2081820
15
Operador de Concatenación
Se representa por 2 barras verticales (||), y tiene por
función enlazar columnas o cadenas de caracteres a
otras columna, resultando en una nueva columna de
caracteres. Ejemplo:
NOMBRE||''||APELLIDO
--------------------------------------------
Olaf Brandenstein
Jose Caniza Livieres
16
Valores NULOS (NULL)
NULL es un valor no disponible, no asignado,
no conocido o inaplicable; por tanto no tiene
igual significado que CERO (0) o espacio
Si una expresión aritmética contiene valores
nulos, toda la expresión se evalúa como NULL
17
Filas duplicadas
La sentencia SELECT despliega todas las filas,
incluyendo duplicadas (a diferencia de la
operación algebraica)
18
DISTINCT para múltiples columnas
DISTINCT se aplica a todas las columnas en la
sentencia SELECT
19
Comando WHERE
Despliega los datos bajo cierta condición
20
Comando ORDER BY
Permite ordenar los datos
21
Comando ORDER BY
El orden de aparición de las filas lo da la cláusula ORDER
BY
◦ ASC indica orden ascendente, es el valor por defecto
◦ DESC indica orden descendente
22
Comando ORDER BY
La cláusula ORDER BY es la última que
aparece en la sentencia SELECT
No solamente puede ordenarse por campos
de la tabla, sino también por expresiones o
aliases.
Los valores NULL se despliegan:
◦ En primera posición en secuencias descendentes
◦ En última posición en secuencias ascendentes
23
Ordenando Múltiples Columnas
Se puede indicar la “posición” del campo a
ordenar, para no volver a escribir la columna
SQL> SELECT id, nombre_area
2 FROM b_areas
3 ORDER BY 2;
24
Top N-Filas de una consulta
➢ Rownum: Es una pseudo-columna cuyo valor es asignado
a medida que el SELECT va obteniendo las filas, el número
asignado es correlativo y va desde 1 hasta N, donde N es
el total de filas obtenidas en la consulta.
Su uso en la consulta no significa que la fila tenga
asignada un número de forma permanente. En un query no se
puede pedir que se devuelva la fila 10 o 5; pero si la primera
fila.
Ejemplo: Seleccionar los campos id, fecha y monto de 2
ventas cualesquiera atribuidas al cliente con id igual a 2.
Hay dos formas:
SQL>SELECT ROWNUM,ID,FECHA,MONTO_TOTAL
FROM B_VENTAS
WHERE ID_CLIENTE=2
AND ROWNUM<=2;
ROWNUM ID FECHA MONTO TOTAL
------ ---- ----------- ------------
1 1 02/01/2011 7215470
2 3 22/05/2011 2370910
SQL>SELECT ROWNUM,ID,FECHA,MONTO_TOTAL
FROM B_VENTAS
WHERE ID_CLIENTE=2
FETCH FIRST 2 ROWS ONLY;
ROWNUM ID FECHA MONTO TOTAL
------ ---- ----------- ------------
1 1 02/01/2011 7215470
2 3 22/05/2011 2370910
➢ La cláusula FETCH FIRST es incorporada a partir de la
v12c de oracle y su función es clasificar internamente
el conjunto de resultados de la consulta y recuperar el
número especificado de filas del conjunto.
A diferencia de Rownum, esta cláusula se escribe al final
de la consulta; mientras que aquella sólo puede ser
usada en el where.
Ejemplo: Se pide obtener el id, fecha y monto de las 2
mayores ventas atribuidas al cliente con id 2.
SQL>SELECT ID,FECHA,MONTO_TOTAL
FROM B_VENTAS
WHERE ID_CLIENTE=2
ORDER BY 3 DESC
FETCH FIRST 2 ROWS ONLY;
28
Expresiones Negativas
A veces es más fácil limitar las filas resultantes,
excluyendo las filas que uno no quiere que
aparezcan
Operadores lógicos
!= <> ^=
Operadores SQL
◦ NOT BETWEEN
◦ NOT IN
◦ NOT LIKE
◦ IS NOT NULL
29
Operadores IN y BETWEEN
Use el operador BETWEEN para probar valores que se
encuentran “entre” o “fuera de” un rango de valores.
30
Operador LIKE
Se puede usar el operador LIKE para realizar
búsquedas utilizando cadenas de caracteres
Las condiciones de la búsqueda pueden
contener caracteres literales o números
"%" denota ninguno o muchos caracteres
"_" denota un carácter
31
Operador LIKE
El operador LIKE puede usarse como un
opción para algunas comparaciones BETWEEN
SQL> SELECT nombre ||' '|| apellido as Empleado
2 FROM b_empleados
3 WHERE apellido like 'B%‘;
32
Operador SQL IS NULL
Para comparar con valores nulos, use el
operador IS NULL.
No use el operador "=".
33
Condiciones Múltiples
Se pueden usar criterios complejos, combinando
condiciones con operadores AND u OR
AND exige ambas condiciones para ser
VERDADERO
SQL> SELECT codigo_cta, nombre_cta
2 FROM b_cuentas
3 WHERE id_tipo=1
4 AND imputable='S';
34
Reglas de precedencia
Se puede cambiar las reglas de
precedencia utilizando paréntesis
35
Resumen de la sintaxis
36