Beruflich Dokumente
Kultur Dokumente
Seguridad
La disponibilidad de los datos puede ser restringida a ciertos usuarios. Según los
privilegios que posea cada usuario de la base de datos, podrá acceder a mayor
información que otros.
Velocidad
Forma no-normalizada
Siempre que sea posible, utilizar una sola columna para la clave primaria;
Copyright © 2003 SENA - CEV Comunidad Educativa Virtual - Todos los derechos
reservados.
• Página 4 - Consultas.
OR
Es el "o"
lógico.
Evalúa
dos
condicion
es y
devuelve
un valor
de verdad
si alguna
de las dos
es cierta.
NOT
Negación
lógica.
Devuelve
el valor
contrario
de la
expresión
.
Copyright © 2003 SENA - CEV Comunidad Educativa Virtual - Todos los derechos
reservados.
Por ultimo, haremos un SELECT mas fuerte. Queremos la información del punto
anterior, pero esta vez nos debe mostrar los resultados agrupados por ciudades,
respetando el ordenamiento por sueldo. Es decir, nos mostrara 4 grupos de
resultados, uno por cada ciudad de la lista, y cada grupito estara ordenado por
sueldo.
Como se había explicado previamente, existen tres comandos que caen dentro de
la categoría de DML (Data Manipulation Language). Estos son INSERT,
UPDATE y DELETE. Cada uno de estos tres comandos son usados para insertar,
cambiar o borrar registros en las tablas que hayamos creado dentro de nuestra
base de datos.
Nos ocuparemos del comando INSERT, que nos permite insertar nuevos
registros en una tabla.
Veamos algunos ejemplos para entender bien el uso del comando INSERT.
La única restricción a la hora de borrar registros tiene que ver con la existencia de
restricciones impuestas a través de las FOREIGN KEY. Esto es, si intentamos
borrar un registro de una tabla que este referenciada a otra por medio de una llave
foránea, el gestor de la base de datos no permitirá que borremos el registro.
Por lo tanto: Para que un registro pueda ser borrado sin inconvnientes, ninguna
tabla debe estar haciendo referencia a el.
Observaciones Finales.
Optimización [editar]
Como ya se dijo arriba, y como suele ser común en los lenguajes de acceso
a bases de datos de alto nivel, el SQL es un lenguaje declarativo. O sea,
que especifica qué es lo que se quiere y no cómo conseguirlo, por lo que
una sentencia no establece explícitamente un orden de ejecución.
Existe una ampliación de SQL conocida como FSQL (Fuzzy SQL, SQL
difuso) que permite el acceso a bases de datos difusas, usando la lógica
difusa. Este lenguaje ha sido implementado a nivel experimental y está
evolucionando rápidamente.
CREATE [editar]
Este comando crea un objeto dentro 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.
ALTER [editar]
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.
DROP [editar]
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 1 [editar]
DROP TABLE TABLA_NOMBRE
Ejemplo 2 [editar]
ALTER TABLE ''TABLA_NOMBRE''
(
DROP COLUMN ''CAMPO_NOMBRE1''
)
TRUNCATE [editar]
Este comando trunca todo el contenido de una tabla. La ventaja sobre el
comando DELETE, 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 solo 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 [editar]
TRUNCATE TABLE ''TABLA_NOMBRE''
INSERT [editar]
Una sentencia INSERT de SQL agrega uno o más registros a una (y sólo
una) tabla en una base de datos relacional.
Ejemplo [editar]
INSERT INTO agenda_telefonica (nombre, numero) VALUES ('Roberto
Fernández', '4886850');
Cuando se especifican todos los valores de una tabla, se puede utilizar la
sentencia acortada:
Para hacer lo mismo en Oracle se usa DUAL TABLE, siempre que se trate
de solo una simple fila:
SELECT *
FROM phone_book
WHERE name IN ('John Doe', 'Peter Doe')
SELECT *
FROM NEW TABLE ( INSERT INTO phone_book VALUES ( 'Peter
Doe','555-2323' ) ) AS t