Documentos de Académico
Documentos de Profesional
Documentos de Cultura
SOLEJE3MSQLMDtemp PDF
SOLEJE3MSQLMDtemp PDF
1.
Para ver qu contiene la tabla sucursales, o seleccionar todas sus filas escribimos
nuestra primera instruccin SELECT :
Esta tabla est formada por dos columnas: Id y Descripcion. Los nombres de columnas
tampoco pueden llevar tildes. Debajo de los nombres estn los valores. Tenemos una
fila, por ejemplo, donde Id vale 2 y Descripcion es "Unin". Para averiguar ms sobre
esta tabla escribimos:
1.6. Sentencia DESCRIBE.
Se sugiere al alumnado que explore, usando SELECT * FROM ... y DESCRIBE ...,
sobre
las
diversas
tablas
de
la
base
de
datos
empresa.
2. Sentencia SELECT
Para extraer informacin de una base de datos, utilizamos una consulta a travs de una
instruccin SELECT.
Para presentar los valores de una columna determinada de una tabla, usamos
SELECT Nombre_de_columna FROM Nombre_de_tabla;
Ejemplo :
Nombre_de_columna_2,...
FROM
Ejemplo:
Obsrvese que los clientes, vendedores, artculos y sucursales son identificados por su
Id. El importe representa el total de la venta, no el precio unitario. Tambin se pueden
hacer clculos con una columna numrica.
Ejemplos:
10
Se puede solicitar que no haya repeticiones en las filas seleccionadas. Basta agregar
DISTINCT despus del SELECT.
Ejemplo:
Los resultados de clculos, si no se toma alguna medida al respecto, a veces salen con
demasiados decimales. En esos casos, conviene usar la funcin ROUND. Esta funcin
redondea los nmeros a la cantidad deseada de decimales despus del punto. Por
ejemplo, ROUND(2.343,2) produce el resultado 2.34. Anlogamente ROUND(2.347,2)
produce 2.35, y ROUND(2.245,2) produce 2.34. Para redondear a un entero alcanza con
escribir ROUND(nmero). Por ejemplo, ROUND(2.345) produce 2.
Ejemplo:
11
En el ltimo punto hemos visto por primera vez una funcin. Una funcin consta de un
nombre, seguido de parntesis, entre los cuales segn los casos puede no haber nada, o
haber una o ms variables. La funcin realiza ciertos clculos con los valores de dichas
variables, y genera otra cantidad, llamada el valor de la funcin. Una consideracin
prctica es que no se pueden dejar espacios entre el nombre de la funcin y el primer
parntesis despus del mismo. Siempre escribiremos parntesis despus del nombre de
una funcin.
2.1. Clusula WHERE.
Esta clusula sirve para seleccionar filas, dentro de las columnas seleccionadas.
WHERE significa "donde". Se pueden seleccionar filas donde una columna tiene un
valor determinado.
Ejemplo:
Vemos que de entre todos los clientes hemos obtenido solamente aqul registro para el
que el identificador id es igual a uno.
Se puede seleccionar filas donde una columna tiene un valor mayor (o menor) que uno
dado.
Ejemplo:
12
Este SELECT listar los clientes con nombre empezando en una letra anterior a "i" en el
alfabeto.
Tambin se aplican a fechas la igualdad y desigualdad. Para referirse a una fecha, se le
escribe como "Ao con 4 cifras-Mes-Da". Por ejemplo, "2004-12-20" indica el 20 de
Diciembre de 2004.
Ejemplo:
13
Para saber si no es
Ejemplo:
No debe usarse <> NULL. Produce resultados equivocados, en su lugar habra que usar
IS NOT NULL.
Llamamos condiciones simples a las siguientes
Expresin
Significado
a=b
a es igual a b
a=b
a es igual a b
a <> b
a es distinto de b
a<b
a es menor que b
a>b
a es mayor que b
a <= b
a es menor o igual a b
a >= b
a es mayor o igual a b
a IS NULL
a es NULL
a IS NOT NULL
a no es NULL
Las cantidades a y b pueden ser nmeros, cadenas de caracteres o fechas, en todos los
casos. En una clusula WHERE se puede usar cualquier condicin simple. La clusula
WHERE selecciona aquellas filas en que la condicin es verdadera.
Las condiciones simples pueden aparecer combinadas por operadores lgicos. Los
operadores lgicos son AND, OR y NOT. Aqu E y F representan condiciones.
Expresin
Significado
X AND Y
XyY
X OR Y
X o Y o ambos
X es verdadera o Y lo es o
ambas
NOT X
No X
X es falsa
14
NOTA : El operador NOT requiere parntesis. Es decir se debe escribir WHERE NOT
(salario > 50) mientras que es incorrecto WHERE NOT salario > 50. Se entiende que
buscamos filas con salarios no mayores que 50.
Ejemplos:
Listar los empleados cuya fecha de ingreso sea anterior al 2004, o cuyo salario sea
mayor que 50 ( o ambas cosas).
El resultado es "Empty set", es decir, no hay filas que cumplan la condicin. En el caso
de condiciones ms complicadas se recomienda un amplio uso de parntesis.
15
125
486
222
125
222
Diana Prez
Alejandro Bentancourt
Jorge Rodrguez
Diana Prez
Adriana Salgado
1/1/2004
30/12/2005
2/5/2004
3/8/2004
1/3/2002
12313
45646
78987
654654
12312
Diana Prez
Diana Prez
1/1/2004
3/8/2004
12313
654654
16
222
222
486
Adriana Salgado
Jorge Rodrguez
Alejandro Bentancourt
1/3/2002
2/5/2004
30/12/2005
12312
78987
45646
Por ltimo, se puede ordenar por una cantidad calculada a partir de una o varias
columnas.
17
18
Solucin:
Solucin: Queremos obtener todas las columnas de las filas de Empleados para las
cuales Salario es mayor que 10500,50.
Obsrvese el uso del punto decimal. Las comas no se pueden utilizar ni en lugar del
punto decimal ni para separar los miles.
4. Queremos obtener los datos del funcionario Carlos Zaltzman.
Solucin: Se trata de obtener una fila de Empleados, aquella en la cual el nombre del
funcionario es Carlos Zaltzman.
19
Solucin: Queremos obtener las filas de Empleados con fecha de ingreso mayor que
'2000-1-1'. La consulta es:
8. Obtener una lista de los nombres de los clientes de los cuales no se tiene direccin.
20
Solucin: Se trata de obtener la columna Nombre de las filas de la tabla Clientes cuya
direccin es NULL.
9. Sacar una lista de los nombres y direcciones de los clientes de los cuales s se tiene
la direccin.
10. Obtener una lista de los diferentes salarios que se pagan en la empresa.
Solucin:
11. Obtener una lista ordenada alfabticamente de los nombres y direcciones de los
clientes, ordenados por nombre.
Solucin:
21
12. Obtener una lista de todos los datos de los empleados ordenados por nombre.
Solucin:
13. Obtener una lista de los datos de los empleados ordenados por salario en forma
descedente. Los salarios deben ser formateados con comas cada 3 dgitos y dos
decimales despus del punto y alineados a la derecha, por ejemplo, 1,200,340.50.
Solucin:
14. Igual al anterior pero se quiere que los nmeros salgan formateados con puntos cada
3 dgitos y coma decimal, en vez de punto. Por ejemplo, 1.200.340,50 .
Solucin:
22
Si bien es un procedimiento complicado, para usarlo en otro caso slo hay que copiar la
parte que comienza con REPLACE y termina en el parntesis antes de AS Salario y
hacer los siguientes cambios:
1.
Cambiar la columna Salario por la que se vaya a usar.
2.
Eventualmente cambiar el nmero de decimales despus de la coma, que figura
dentro de la funcin FORMAT, de 2 al valor que se desee.
3.
Si es conveniente, variar el ancho de la columna. Este ancho aparece dentro de la
funcin LPAD. En este ejemplo vale 12. El ancho debe ser suficiente para poder escribir
todos los valores que aparezcan en la columna, con el nmero de decimales que se haya
solicitado.
O este otro:
52
usado COUNT (DISTINCT ....) para contar cuntos elementos distintos hay en
una expresin calculada en base a una columna.
ar
Valor de la columna A
'Carlos'
Verdadera
'carlos'
Verdadera
'Carlos '
Falsa
'Juan'
Falsa
'Juan Carlos'
Falsa
Verdadera
'carlos'
Verdadera
'Carlos Zaltzman'
Verdadera
'Carlos '
Verdadera
'Juan'
Falsa
'Juan Carlos'
Falsa
53
Valor de la columna A
'Carlos'
Verdadera
'carlos'
Verdadera
'Juan carlos'
Verdadera
Falsa
Falsa
Valor de la columna A
'Carlos'
Verdadera
'carlos'
Verdadera
Verdadera
Verdadera
'Juan'
Falsa
Valor de la columna A
'Carlos'
Falsa
'12Carlos'
Verdadera
'xxCarlos'
Verdadera
' Carlos'
Verdadera
'xxcarlos'
Verdadera
'Juan Carlos'
Falsa
Problemas resueltos
54
Solucin:
2. Hacer una lista de todos los datos de los artculos en cuyo nombre figura la
m
Solucin:
Solucin:
Solucin:
55
Solucin:
Solucin: