Sistemas Informáticos I Resumen
|
|
- Isabel Benítez Soriano
- hace 8 años
- Vistas:
Transcripción
1 Sistemas Informáticos I Resumen Alejandro Bellogín Kouki 20 de enero de Modelo Entidad-Relación y tablas 1.1. Modelo E-R Entidad rectángulo Relaciones rombos Uno a uno! Uno a muchos! Muchos a muchos Cardinalidad limitada M::N! Atributos elipses Multivaluados: elipses dobles Derivados: elipses punteadas Clave primaria subrayada Herencia triángulo invertido Entidad débil doble rombo en la relación, doble rectángulo en la relación, subrayado discontinuo en los atributos discriminantes 1.2. Reicación Relación entre A y B Operación con A(a1, a2), B(b1, b2) Uno a uno A(a1, a2, b1"), B(b1, b2) ó A(a1, a2), B(b1, b2, a1") Uno a muchos A(a1, a2), B(b1, b2, a1") Muchos a muchos A(a1, a2), B(b1, b2), C(a1", b1") Atributos compuestos Igual que uno a uno con sus partes atómicas Atributos multievaluados Igual que uno a muchos (el atributo es el lado de muchos) Entidades débiles (B de A) A(a1, a2), B(b1, b2, a1") (b1discriminante) Especialización (B IS-A A) A(a1, a2), B(b1, b2, a1") 1.3. Álgebra relacional Selección p(r) = ft : t 2 r and p(t)g Proyección A1;A2;:::;Ak(r) devuelve los k atributos de la tabla r Unión r [ s = ft : t 2 r or t 2 sg Diferencia r s = ft : t 2 r and t 2 sg Producto cartesiano r s = ftq : t 2 r and q 2 sg 1
2 2 LENGUAJE SQL 2 Renombramiento X(E) devuelve la expresión E bajo el nombre X Intersección r \ s = r (r s) = ft : t 2 r and t 2 sg Producto natural r on s = f R[S(r:Bi=s:Bi(r s))g, donde Bi son todos los atributos que tengan en común las relaciones r (con esquema R = (A1; : : : ; Am; B1; : : : ; Bn)) y s (con esquema S = (B1; : : : ; Bn)) Reunión externa por la izquierda r Aos hace el producto natural entre r y s pero añadiendo todas las columnas de r, de forma que si algún atributo de s no existe, se rellena con NULL Reunión externa por la derecha rn@ s = s Aor Reunión externa total r Ao@ s = (r Aos) [ (r Aos) División r s = ft : t 2 R S(r) ^ 8u 2 s(tu 2 r)g que tiene esquema R S = (A1; : : : ; Am) Asignación permite fragmentar consultas Agregación G1;:::; GnGF1(A1);:::;Fn(An)(E) donde Gi son los atributos a agrupar y Fi 2 favg, min, max, sum, countg Hay que notar que: Los operadores se pueden componer. Cuando se usan dos relaciones los operadores siempre necesitan que estas sean compatibles. 2. Lenguaje SQL 2.1. Denición de datos Tipos de datos CHAR(n), VARCHAR(n), INT, NUMERIC(p,d) Creación y destrucción Se pueden crear (CREATE) o destruir (DROP) lo siguiente: tablas (table), secuencias (SEQUENCE), funciones (FUNCTION) Restricciones Arbitraria (CHECK), no valores nulos (NOT NULL), no valores repetidos (UNIQUE), clave primaria (PRIMARY KEY), clave extranjera (FOREIGN KEY) Cambiar una tabla Se usa ALTER TABLE <tabla> ADD f CHECK, CONSTRAINT, FOREIGN KEY, COLUMN g ALTER TABLE <tabla>alter COLUMN <atributo> SET f NOT NULL, DEFAULTg ALTER TABLE <tabla>rename COLUMN <atributo> TO <nuevo-nombre> ALTER TABLE <tabla>drop <atributo> 2.2. Consultas Quitar duplicados DISTINCT Comparación de caracteres LIKE, [NOT] SIMILAR TO, donde el segundo permite expresiones regulares, y el primero toma caracteres especiales en la comparación % para cualquier carácter y _ para sólo uno. Selección, proyección, agrupación, ordenación Se consigue con SELECT <atributo> FROM <tabla> WHERE <condicion> GROUP BY <atributo> HAVING <condicion> ORDER BY <atributo> 1. Crear el producto descrito en FROM 2. Aplicar restricciones descritas en WHERE 3. Si hay GROUP BY agrupar las tuplas según se especique, aplíquese HAVING y SELECT 4. En otro caso, aplíquese SELECT (proyectar) Insertar Se pueden especicar los atributos a insertar o, si no se hace, se insertarán en orden INSERT INTO <tabla> VALUES() Borrar DELETE FROM <tabla>where <condicion>
3 3 PHP 3 Actualizar UPDATE <tabla>set <nuevo> WHERE <condicion> Puede no haber condición. Condiciones en subconsultas Se tiene 1. EXISTS r: verdadero si r es una relación no vacía 2. s IN r: verdadero si s está en r (si s es un escalar, r debe tener sólo un atributo) 3. s op ALL r: verdadero si s cumple op para todos los valores de r 4. s op ANY r: verdadero si s cumple op para alguno de los valores de r 2.3. Triggers Evento! condición! acción CREATE TRIGGER nombre BEFORE/AFTER INSERT/DELETE/UPDATE OF atributo ON tabla REFERENCING OLD ROW AS old, NEW ROW AS new, FOR EACH ROW WHEN condicion BEGIN ATOMIC... END PL/pgSQL Sólo permite la ejecución de una función. No permite disparar cuando se modican columnas especícas. CREATE TRIGGER nombre BEFORE/AFTER INSERT/DELETE/UPDATE ON t a b l a FOR EACH ROW EXECUTE PROCEDURe funcion ( ) ; CREATE FUNCTION funcion ( ) RETURNS TRIGGER AS ' DECLARE... BEGIN... END; ' LANGUAGE ' plpgsql ' 3. PHP Lenguaje estructurado interpretado. Se ejecuta en el servidor. Código entre <?php...?>. No es fuertemente tipado. Variables: empiezan con el símbolo $, para ser evaluadas se pueden colocar entre comillas dobles. Las variables del sistema (superglobales) son siempre arrays. Constantes: define("constant", "Hello world"); Las matrices o arrays pueden ser asociativos, donde cada valor se asocia a una clave. Bases de datos: pg_connect(), pg_query(), pg_free_result(), pg_close(). Si se quiere que tarden menos en ejecutarse, las consultas se pueden preparar: pg_prepare(), pg_execute(). Para manejar los resultados de pg_query(), pg_execute() se convierte a matriz: pg_fetch_row(), pg_fetch_array(), pg_fetch_object().
4 4 NORMALIZACIÓN 4 4. Normalización Todos los atributos de una relación deben ser atómicos y depender única y totalmente de la clave primaria Primera forma normal (1FN) Los atributos de las relaciones son atómicos (unidades indivisibles). Para convertir una relación en 1FN se crea una nueva relación con el grupo que se repite, se añade a esta nueva relación la clave primaria de la relación que originalmente la contenía Segunda forma normal (2FN) Todos los atributos deben depender de toda la clave primaria, y no de una parte de ella. Hay que eliminar los atributos que dependen parcialmente de la clave primaria, crear con ellos una nueva relación y añadir a esta relación una copia de los atributos de los que dependían (clave primaria de la relación nueva) Tercera forma normal (3FN) Los atributos dependen directamente de la clave primaria (y no a través de otro atributo). Se consigue con el mismo procedimiento que para 2FN pero con los atributos que presenten dependencias transitivas. 5. SQL en entorno de programación C Los comandos deber ir después de la orden EXEC SQL El precompilador ecpg se encarga de procesar estas órdenes y trasladarlas a llamadas a una librería. Una vez hecho esto, se puede compilar normalmente (gcc). Para utilizar variables declaradas en código C y usarlas en SQL se hace: EXEC SQL begin d e c l a r e s e c t i o n ; int numero ; EXEC SQL end d e c l a r e s e c t i o n ; EXEC SQL SELECT t.num INTO : numero FROM tabla AS t ; Para tratar el valor NULL se utilizan variables indicadoras que contienen códigos que sirven para matizar los valores devueltos por la base de datos (si es 0 el valor es correcto, si es 1 el valor debe tratarse como NULL y en otro caso indica que la variable ha sufrido algún procesamiento: redondeo, truncación). Para manejar errores se utiliza el campo sqlcode de la estructura sqlca (valor cero indica que la consulta es correcta, positivo indica alguna excepción y negativo un error). Se puede tratar de manera más automática con whenever <condicion> <accion> Para conseguir capturar varias tuplas debemos usar cursores: declarar, abrir, avanzar, cerrar: EXEC SQL DECLARE <cursornombre > CURSOR FOR < consulta >; EXEC SQL OPEN <cursornombre >; EXEC SQL FETCH <cursornombre > INTO : variable1, : v a r i a b l e 2 ; EXEC SQL CLOSE <cursornombre >; Por defecto los cursores son sólo de lectura, pero se pueden declarar para ser usados para modicar y borrar tuplas (FOR UPDATE OF <tabla>.<atributos>). SQL dinámico: para ejecutar una sentencia arbitraria en algún momento se utiliza EXEC SQL EXECUTE IMMEDIATE < consulta >; Normalmente la consulta va a ser creada dinámicamente. Además, no puede devolver datos (no se permite SELECT, pero sí INSERT o UPDATE). Se pueden preparar consultas: EXEC SQL PREPARE < consulta > FROM : < consultastring >; EXEC SQL EXECUTE < consulta > USING <parametro1 >, <parametro2 >;
5 6 TRANSACCIONES 5 6. Transacciones Una transacción es una colección de operaciones de lectura y escritura que están relacionadas a nivel lógico: Deben ocurrir en su totalidad o no ocurrir en absoluto (atomicidad). Si la transacción se ejecuta los efectos de las operaciones de escritura deben persistir (COMMIT); si no se completa no se debe producir ningún efecto (ROLLBACK). Situación ideal: transacciones en serie; pero produce un rendimiento muy bajo. Existen grados de aislamiento: SET TRANSACTION ISOLATION LEVEL < level > donde los distintos niveles pueden ser: En serie: SERIALIZABLE. Por defecto: READ COMMITED. No permite la lectura de datos uncommited pero una misma consulta en una transacción puede devolver distintos resultados. Ningún valor escrito por la transacción se puede modicar hasta que termina. Si se ven los grados de aislamiento como bloqueos, se haría: Bloqueo compartido: antes de leer. Bloqueo exclusivo: antes de escribir. Se pueden realizar a distintos niveles, aunque PostgreSQL sólo permite a nivel de tabla. Modo actual Ninguno Compartido Exclusivo Modo Compartido Otorgado Otorgado No otorgado solicitado Exclusivo Otorgado No otorgado No otorgado Si una transacción solicita un bloqueo debe esperar a que se le conceda, después de un tiempo aborta y se ejecuta ROLLBACK. 7. Optimización Para minimizar el tiempo de búsqueda de una columna de una tabla se crea un índice sobre esa columna. CREATE INDEX <nombre_indice > ON <tabla > (<columna ( s )>) ; Se crean automáticamente para claves primarias. Para que tenga efecto hay que actualizar los datos. Podemos decirle a PostgreSQL que nos muestre cómo planea (estima) ejecutar una consulta. EXPLAIN [ ANALYZE ] [ VERBOSE ] < consulta > Para que muestre datos realistas hay que actualizar los datos. Se puede ver, por ejemplo, que cuando se hace GROUP BY por un campo que no tiene índice, el sistema debe ordenar el resultado, por lo que el tiempo de la consulta aumenta bastante. Actualizar datos: VACUUM VERBOSE ANALYZE < tabla > de esta forma, se generan estadísticas que luego se pueden usar para determinar la ejecución más eciente de las consultas.
6 8 SEGURIDAD Y RESTRICCIONES DE INTEGRIDAD 6 8. Seguridad y restricciones de integridad 8.1. Seguridad en SQL Se puede denir qué comandos puede usar un usuario particular y sobre qué relaciones. Esto se puede hacer tanto a usuarios como a grupos (GROUP <nombre>) o a todos en general (con PUBLIC conguramos hasta los privilegios de los usuarios futuros). GRANT sirve para dar permisos y REVOKE para quitarlos GRANT { { SELECT INSERT UPDATE DELETE RULE REFERENCES TRIGGER } [,... ] ALL PRIVILEGES } ON [ TABLE ] < nombre_tabla1 > [,... ] TO { < nombre_usuario1 > GROUP <nombre_grupo1 > PUBLIC } [,... ] [ WITH GRANT OPTION ] REVOKE [ GRANT OPTION FOR ] { { SELECT INSERT UPDATE DELETE RULE REFERENCES TRIGGER } [,... ] ALL PRIVILEGES } ON [ TABLE ] < nombre_tabla1 > [,... ] FROM { < nombre_usuario1 > GROUP <nombre_grupo1 > PUBLIC } [,... ] [ CASCADE RESTRICT ] Si al dar privilegios se escribe la opción WITH GRANT OPTION entonces ese usuario podrá dar privilegios a otros, por ello, se hace necesario CASCADE para permitir quitar todos los privilegios de los usuarios. Hay otras formas de llamar a GRANT para permitir ejecutar funciones ( GRANT EXECUTE ON FUNCTION <nombre_funcion1 > ([ type,... ] ) [,... ] TO <... > ) o crear funciones o dominios en un lenguaje ( ) entre otros. GRANT USAGE ON LANGUAGE <nombre_lenguaje1 > [,... ] TO <... > PostgreSQL no permite congurar privilegios sobre columnas, una posible solución es crear una vista que muestre las columnas deseadas y dar privilegios a la vista. SQL no permite autorizar a nivel de tupla (esto se puede hacer a nivel más alto) Restricciones de integridad Restricciones de dominio: tipos de datos personalizados. create domain <nombre_tipo> <tipo > [ DEFAULT < expresion > ] [ < r e s t r i c c i o n e s > ] ; Control de restricciones: check. Hay que tener en cuenta que cuanto más compleja sea la restricción más le constará al sistema modicar o añadir tuplas. Además, no se permiten subconsultas en esta restricción, es decir, no está permitido create table tabla2 ( num int, num2 int check ( num2 in ( select num from tabla ) ) ) ; Armaciones (assertions): expresiones que se deben satisfacer siempre create assertion <nombre> check < predicado > El sistema debe comprobar tras cada inserción o modicación si la armación se cumple o no, por lo que consume muchos recursos. No está soportado por PostgreSQL.
El Lenguaje SQL TEMA V. Grupo de Bas ses de Datos Avanzadas Univ. Carlo os III de Madrid. V.1 SQL como Lenguaje de Definición de Datos
Grupo de Bases de Datos Avanzadas Univ. Carlos III de Madrid Índice V.1 Introducción V.1 SQL como Lenguaje de V.1.1 Definición del esquema V.1.2 Evolución del esquema V.2 SQL como Lenguaje de Manipulación
Más detallesSQL (Structured Query Language)
SQL (Structured Query Language) El lenguaje de consulta estructurado o SQL (por sus siglas en inglés Structured Query Language) es un lenguaje declarativo de acceso a bases de datos relacionales que permite
Más detallesBase de datos relacional
Base de datos relacional Una base de datos relacional es una base de datos que cumple con el modelo relacional, el cual es el modelo más utilizado en la actualidad para modelar problemas reales y administrar
Más detallesRestricciones de Integridad
Restricciones de Integridad Amparo López Gaona México, D.F. Semestre 2000-I Restricciones de Integridad Las principales restricciones de integridad que pueden indicarse son: La clave primaria. Claves candidatas.
Más detallesPermite definir cada relación que pertenece a la base de datos relacional, incluyendo:
TEMA 7.- EL ESTANDAR SQL. El Sublenguaje de Manipulación. El Sublenguaje de Definición. El Sublenguaje de Control. El Sublenguaje Huésped. 1. El Sublenguaje de Manipulación. (Se verá en la clase de problemas)
Más detallesSQL. (...la guía básica de supervivencia de dmi) Universidad de los Andes Demián Gutierrez Enero 2009 1
SQL (...la guía básica de supervivencia de dmi) Universidad de los Andes Demián Gutierrez Enero 2009 1 Crear una Tabla (Esquema de Relación) (1) (Cascadas) postgres=# CREATE TABLE departamento ( codigo
Más detalles- Bases de Datos - - Diseño Físico - Luis D. García
- Diseño Físico - Luis D. García Abril de 2006 Introducción El diseño de una base de datos está compuesto por tres etapas, el Diseño Conceptual, en el cual se descubren la semántica de los datos, definiendo
Más detallesSINTAXIS DE SQL-92. <definición de esquema >::= CREATE SCHEMA <cláusula de nombre de esquema> [ <elemento de esquema>... ]
SINTAXIS DE SQL-92 Introducción: Se presenta brevemente un resumen de la sintaxis de SQL según el estándar ISO 9075 (SQL- 92), dividido en tres partes: - Lenguaje de Definición de Daots (LDD), - Lenguaje
Más detallesEl usuario puede utilizar esta tabla derivada como una tabla más, en sus consultas.
Vistas. El resultado de una consulta en el caso de SQL siempre es una tabla, ésta se puede hacer permanente dentro de la base de datos. En este caso se dice que esta tabla resultado es una vista o una
Más detallesTEMA 6: MODIFICACIÓN DE LA BASE DE DATOS EN SQL
TEMA 6: MODIFICACIÓN DE LA BASE DE DATOS EN SQL 5.6 MODIFICACIÓN DE LA BASE DE DATOS SQL posee comandos destinados también para modificar la base de datos, entre estos se tienen operaciones de borrado,
Más detallesLenguaje para descripción de datos
Amparo López Gaona tación Fac. Ciencias, UNAM Mayo 2012 Definición de Datos El lenguaje para definición de datos permite especificar: Esquema de cada relación. El dominio de cada atributo. Restricciones
Más detallesSQL Los fundamentos del lenguaje
Introducción 1. Un poco de historia 11 2. Las normas SQL 12 3. Descripción rápida del modelo relacional 14 3.1 Principales conceptos del modelo relacional 15 3.2 Principales reglas 16 4. Los operadores
Más detallesÍNDICE INTRODUCCIÓN...13
ÍNDICE INTRODUCCIÓN...13 CAPÍTULO 1. EL MODELO RELACIONAL. LENGUAJE SQL...17 1.1 INTRODUCCIÓN AL MODELO RELACIONAL...17 1.2 RELACIONES...19 1.2.1 Definición formal de relación...21 1.2.2 Propiedades y
Más detalles8 SQL SERVER 2008 RA-MA
ÍNDICE Capítulo 1. Características, novedades y entorno de trabajo... 17 1.1 Novedades en SQL Server 2008... 17 1.2 Instalación de Microsoft SQL Server 2008... 19 1.3 Versiones de Microsoft SQL Server
Más detallesBases de Datos 2. Teórico
Bases de Datos 2 Teórico Structured Query Language (SQL) Características de SQL Standard Opera sobre conjuntos de tuplas: incluso para las operaciones de inserción, borrado y actualización. No elimina
Más detallesIntegridad y Seguridad. Integridad y Seguridad. Restricción de Dominio. Protección. Índice. create domain. Dominios
Protección Integridad y Seguridad Las Restricciones de Integridad aseguran que las modificaciones realizadas por usuarios autorizados no provocan perdidas de Consistencia Semántica El Control de Acceso
Más detallesLenguaje de Consulta Estructurado S Q. Lenguaje de Consulta Estructurado. Wael Najjar /
S Q Lenguaje de Consulta Estructurado L Wael Najjar / Wael Stephenson Najjar / Prieto Stephenson Prieto Contenido Parte I El Lenguaje de Consulta Estructurado. Lo que se puede hacer. Lenguaje Estandarizado.
Más detalles2.6.2.- Aplicaciones de las vistas. 2.6.1.- Concepto de vista. 2.6.3.- Vistas en SQL. 2.6.3.- Vistas en SQL.
2.6.1.- Concepto de vista. Una vista es una tabla derivada de otras tablas (básicas o virtuales). Una vista se caracteriza porque: Se considera que forma parte del esquema externo. Una vista es una tabla
Más detallesRESTRICCIONES DE DOMINIOS
RESTRICCIONES DE DOMINIOS - Cargo del personal de la inmobiliaria: create domain cargo_personal as character20 check value in Venta, Alquiler, Gerencial - Categoría del barrio: create domain categoría
Más detallesESCUELA DE CIENCIAS BASICAS TECNOLOGIA E INGENIERIA 301127- Programación de sitios web Act 11: Reconocimiento de la unidad 3
GESTORES DE BASES DE DATOS Existen varios tipos de Sistemas gestores de bases de datos SGBD, según el modelo de datos que utilizan. Son estos: bases jerárquica, en red, relacional, y bases de datos orientadas
Más detallesUniversidad Nacional del Sur Departamento de Ciencias e Ingeniería de la Computación Elementos de Bases de Datos 2do. Cuatrimestre de 2004
2do. Cuatrimestre de 2004 Elementos de Bases de Datos Dpto.Ciencias e Ingeniería de la Computación Universidad Nacional del Sur Lic. María Mercedes Vitturini [mvitturi@cs.uns.edu.ar] Clase 14 1er. Cuatrimestre
Más detallesDiseño de bases de datos
Departamento de Lenguajes y Sistemas Informáticos E.T.S. Ingeniería Informática. Universidad de Sevilla Avda Reina Mercedes sn. 41012 Sevilla TlfFax 954 557 139 E-mail lsi@lsi.us.es Web www.lsi.us.es Diseño
Más detalles1. DML. Las subconsultas
1.1 Introducción 1. DML. Las subconsultas Una subconsulta es una consulta que aparece dentro de otra consulta o subconsulta en la lista de selección, en la cláusula WHERE o HAVING, originalmente no se
Más detalles8 MICROSOFT SQL SERVER 2008 R2. CURSO PRÁCTICO RA-MA
ÍNDICE CAPÍTULO 1. CARACTERÍSTICAS, NOVEDADES Y ENTORNO DE TRABAJO...17 1.1 NOVEDADES EN SQL SERVER 2008 R2...17 1.2 INSTALACIÓN DE MICROSOFT SQL SERVER 2008 R2...18 1.3 VERSIONES DE MICROSOFT SQL SERVER
Más detallesBases de Datos SQL 1 SQL. Jorge Pérez R. Universidad de Talca, II Semestre 2006
Bases de Datos SQL 1 SQL Jorge Pérez R. Universidad de Talca, II Semestre 2006 Bases de Datos SQL 2 Structured Query Language Lenguaje de consulta para bases de datos comerciales. Originalmente llamado
Más detallesStructured Query Language (SQL) Fundamentos de Bases de Datos InCo - 2011
Structured Query Language () Fundamentos de Bases de Datos InCo - Un poco de historia Lenguajes de consulta relacionales: SEQUEL (IBM-1970) QUEL (Ingres-1970) QBE (IBM-1970) es el lenguaje comercial más
Más detallesTema 33. El lenguaje SQL
Tema 33. El lenguaje SQL Introducción... 1 Modos de uso... 2 Ejecución de las sentencias SQL... 2 Instrucciones DDL Data Definition Language-... 3 Instrucciones DML Data Manipulation Language-... 4 Instrucciones
Más detallesLAS SUBCONSULTAS SQL SERVER 2005. Manual de Referencia para usuarios. Salomón Ccance CCANCE WEBSITE
LAS SUBCONSULTAS SQL SERVER 2005 Manual de Referencia para usuarios Salomón Ccance CCANCE WEBSITE LAS SUBCONSULTAS Una subconsulta es una consulta que aparece dentro de otra consulta o subconsultas, en
Más detallesBASES DE DATOS SQL MÁS S DE SQL (DML) OPERADOR UNION (L30) <SELECT1> UNION <SELECT2> UNION <SELECTN> Copyright 2006, 2007 Instituto Gala
OPERADOR UNION (L30) UNION UNION OPERADOR INTERSECCION (L31) OPERADOR RELACIONAL INTERSECCION, DEVUELVE REGISTROS CON CAMPOS COMUNES. LAS TABLAS INVOLUCREADAS DEBEN TENER
Más detallesBASE DE DATOS - CURSO 02/03 PRÁCTICA 2: SQL: Lenguaje de definición de datos (DDL)
OBJETIVOS: Enseñar al alumno las sentencias que forman el lenguaje de definición de datos de SQL, es decir, el subconjunto de órdenes que nos permitirán crear o editar esquemas de bases de datos. MATERIAL:
Más detallesT12 Vistas y tablas temporales
1 de 9 17/05/2013 14:01 Lecciones SQL > T12 Vistas y tablas temporales En esta sesión vamos a mostrar dos tipos de objetos de uso habitual en cualquier SGBD: las vistas y las tablas temporales. Mientras
Más detallesA.1. Definiciones de datos en SQL
A.1. Definiciones de datos en SQL Las Sentencias del lenguaje de definición de datos (DDL) que posee SQL operan en base a tablas. Las Principales sentencias DDL son las siguientes: CREATE TABLE DROP TABLE
Más detallesTema 4. SQL. Juan Ignacio Rodríguez de León
Tema 4. SQL Juan Ignacio Rodríguez de León Resumen Este tema se centra exclusivamente en el estudio del lenguaje de consultas SQL (Structured Query Language). SQL usa una combinación de álgebra relacional
Más detallesUnidad III: Lenguaje de manipulación de datos (DML) 3.1 Inserción, eliminación y modificación de registros
Unidad III: Lenguaje de manipulación de datos (DML) 3.1 Inserción, eliminación y modificación de registros La sentencia INSERT permite agregar nuevas filas de datos a las tablas existentes. Está sentencia
Más detallesCURSO DE SQL SERVER 2005
CURSO DE SQL SERVER 2005 Una vez finalizado el curso, el alumno estará preparado para: Instalar y configurar SQL Server 2005. Comprender los conceptos más importantes del diseño de bases de datos. Crear
Más detallesIntegridad y Seguridad en los sistemas de Bases de Datos. Javier Escobar Luis Ramirez Omar Asprino
Integridad y Seguridad en los sistemas de Bases de Datos Javier Escobar Luis Ramirez Omar Asprino Contenido 1. Restricciones de Integridad 1. Claves Primarias 2. Restricciones de los Dominios 3. Integridad
Más detallesMANUAL BÁSICO DEL LENGUAJE SQL
MANUAL BÁSICO DEL LENGUAJE SQL ESCUELA COLOMBIANA DE INGENIERÍA JULIO GARAVITO LABORATORIO DE INFORMÁTICA BOGOTÁ D. C. 2007-2 TABLA DE CONTENIDO INTRODUCCIÓN... 3 1. COMANDOS... 4 1.1 Comandos DLL... 4
Más detallesSistemas de Datos Curso: Ernesto Chinkes. Subconsultas Stored Procedures - Triggers
Subconsultas Stored Procedures - Triggers Subconsultas Concepto Ubicación En el SELECT En el FROM En el WHERE Operadores IN ANY-ALL EXISTS Concepto Son sentencias SELECT que aparecen dentro de otra consulta
Más detallesSeguridad en SQL Server 2005
Seguridad en SQL Server 2005 Tabla de contenidos Modelo de Seguridad en SQL Server Inicios de Sesión - Usuarios Esquemas de Base de Datos Usuarios de Base de Datos Contexto de Ejecución Permisos a sentencias
Más detallesBases de Datos: Structured Query Language (SQL)
Structured Query Language (SQL): Introducción Bases de Datos: Structured Query Language (SQL) Franco Guidi Polanco Escuela de Ingeniería Industrial Pontificia Universidad Católica de Valparaíso, Chile
Más detallesÍNDICE PRIMERA PARTE... 17
ÍNDICE PREFACIO... xv PRIMERA PARTE... 17 CAPÍTULO 1. BASES DE DATOS... 19 BASE DE DATOS RELACIONAL... 20 ESTRUCTURA MÍNIMA DE ALMACENAMIENTO... 21 EJEMPLO DE TABLA... 22 RESUMEN... 23 CAPÍTULO 2. CONSULTAS
Más detallesConsultas con combinaciones
UNIDAD 1.- PARTE 2 MANIPULACIÓN AVANZADA DE DATOS CON SQL. BASES DE DATOS PARA APLICACIONES Xochitl Clemente Parra Armando Méndez Morales Consultas con combinaciones Usando combinaciones (joins), se pueden
Más detalles3. El catálogo 26. Laboratorio de Bases de Datos
ÍNDICE Continuación SQL Índice 1. Continuación del SQL como DML (Lenguaje de Manipulación de Datos) 1 1.1. Inserción de datos................................. 1 1.2. Borrado de datos..................................
Más detallesOracle básico (IV): Programación en PL/SQL
Oracle básico (IV): Programación en PL/SQL El lenguaje de programación de Oracle, llamado PL/SQL, es un lenguaje portable, procedural y de transacción muy potente y de fácil manejo, con las siguientes
Más detallesRestricciones (constraints) FOREIGN KEY
INSTITUTO DE EDUCACION TECNICA PROFESIONAL INTEP 1 Restricciones (constraints) FOREIGN KEY InnoDB también soporta restricciones de claves foráneas. La sintaxis para definir una restricción de clave foránea
Más detallesPaso del E-R a tablas
Paso del E-R a tablas Fernando Cano Mayo 2012 1. Entidades Cada entidad del modelo E-R genera una tabla. Dicha tabla contiene como columnas cada uno de los atributos de la entidad. Además puede contener
Más detallesPráctica 3. Consultas SQL
Práctica 3. Consultas SQL 1. Enunciado En este ejercicio se realizarán consultas SQL que respondan a las preguntas que se plantearán sin utilizar QBE. Dada una base de datos denominada Empresa y definida
Más detallesResumen. El rol del lenguaje SQL en los SGBDR y en la Relacional. cjimenez@inf.udec.cl, tamrstro@inf.udec.cl
El rol del lenguaje SQL en los SGBDR y en la Relacional. cjimenez@inf.udec.cl, tamrstro@inf.udec.cl Resumen demandas de almacenamiento y procesamiento de datos. Es el conjunto de estas dos capacidades
Más detallesTema 4. Manipulación de datos con SQL
Tema 4 Manipulación de datos con SQL Índice Tema 4 1. Inserción de registros. Consultas de datos anexados. 2. Modificación de registros. Consultas de actualización. 3. Borrado de registros. Consultas de
Más detallesBase de datos I Facultad de Ingeniería. Escuela de computación.
Base de datos I Facultad de Ingeniería. Escuela de computación. Introducción Este manual ha sido elaborado para orientar al estudiante de Bases de datos I en el desarrollo de sus prácticas de laboratorios,
Más detallesEstándar de desarrollo de aplicaciones del Govern de les Illes Balears
Estándar de desarrollo de aplicaciones del Govern de les Illes Balears BASE DE DATOS Versión 5.0 Fecha Revisión: 28/05/09 Índice de contenidos INTRODUCCIÓN... 3 NOMENCLATURA DE BASE DE DATOS... 4 2.1.
Más detallesBase de datos Lenguaje SQL
Base de datos Lenguaje SQL Universidad Nacional Andrés Bello Contenidos 1 2 Ejemplo Ejemplo Distinct Ejemplo - I Ejemplo - II Ejemplo Ejemplo Top - I Ejemplo Top - II Contenidos 1 2 Ejemplo Ejemplo Distinct
Más detallesSQL. Orígenes y Evolución
SQL 1 SQL. Orígenes y Evolución 2 SQL: Estándar oficial 3 Funciones de SQL DDL Data Definition Language Creación n de estructuras de la base de datos Integridad de los datos DML Data Manipulation Language
Más detallesm047a Curso Programando una Base de Datos SQL Server 2008, 36 h Creación B.D. y Constraints
Crear Una Base De Datos (L12) A TRAVÉS DE LA CONSOLA DE ADMINISTRACIÓN A TRAVÉS DEL ASISTENTE DE BASES DE DATOS (DATABASE WIZARD) A TRAVÉS DE COMANDOS SQL (CREATE DATABASE, CREATE TABLE) Crear Un Grupo
Más detallesIntroducción a las bases de datos.
Introducción a las BBDD 1 Centro de Referencia Linux UAM-IBM Introducción a las bases de datos. Carmen B. Navarrete Navarrete carmen_navarrete@telefonica.net Introducción a las BBDD 2 Qué vamos a ver?
Más detallesDesarrollo Cobol/DB2
Desarrollo Cobol/DB2 Preparación de programas Precompilador DB2 Toma los postulados SQL del programa fuente Revisa la sintaxis de SQL Crea un programa fuente traducido de las sentencias SQL Crea el DBRM
Más detallesProcedimientos, Funciones, Trigger y Cursores en ORACLE
Procedimientos, Funciones, Trigger y Cursores en ORACLE PROCEDIMIENTOS ALMACENADOS Un procedimiento almacenado es un conjunto de instrucciones en PL/SQL, que pueden ser llamados usando el nombre que se
Más detallesBASES DE DATOS AVANZADAS Transacciones en MYSQL
Ejercicio Transacciones mysql> CREATE TABLE innotest (campo INT NOT NULL PRIMARY KEY) TYPE = InnoDB; Query OK, 0 rows affected (0.10 sec) mysql> INSERT INTO innotest VALUES(1); Query OK, 1 row affected
Más detallesINTRODUCCIÓN INTRODUCCIÓN INTRODUCCIÓN INTRODUCCIÓN INSTRUCCIONES DE DEFINICIÓN DE TABLAS E ÍNDICES INSTRUCCIONES DE DEFINICIÓN DE TABLAS E ÍNDICES
EL LENGUAJE SQL. INSTRUCCIONES DE DEFINICIÓN DE. INSTRUCCIONES DE INSERCIÓN, MODIFICACIÓN Y BORRADO.. CREACIÓN Y UTILIZACIÓN DE VISTAS... PROCEDIMIENTOS. EL LENGUAJE SQL 1 EL LENGUAJE SQL 2 SQL ES UN LENGUAJE
Más detallesSQL PROCEDURAL Triggers y Stored Procedures. Ing. Gustavo A. Correa Reina UNCPBA 2008
Base de Datos I SQL PROCEDURAL Triggers y Stored Procedures Ing. Gustavo A. Correa Reina UNCPBA 2008 SQL Procedural Posibilita el uso de código procedural conjuntamente con sentencias SQL que son almacenadas
Más detallesManejo de Transacciones
Bases de Datos Transacciones 1 Manejo de Transacciones Jorge Pérez Rojas Universidad de Talca, II Semestre 2006 Bases de Datos Transacciones 2 Transacciones Hasta ahora el modelo de operación en la BD
Más detallesIntegridad en sistemas de bases de datos relacionales
Integridad en sistemas de bases de datos relacionales Competencias específicas a adquirir Asegurar la integridad de los datos mediante la aplicación de los mecanismos soportados por los SGBDs. Identificar
Más detallesUnidad. Lenguaje SQL. (Structured Query Language)
Unidad Lenguaje SQL (Structured Query Language) 1 SQL Definición DDL Consulta y Actualización DML Create Alter Drop Select Insert Update Delete 2 SQL DDL CREATE TABLE nombre_tabla (nombre_columna tipo_dato/dominio
Más detalles1. Introducción: Qué es un Modelo de Datos? 2. Estática del modelo de datos relacional
Tema 7: Modelo Relacional 1. Introducción: Qué es un Modelo de Datos? 2. Estática del modelo de datos relacional Dominios, Atributos, Relaciones Representación del esquema relacional Características de
Más detallesHaga clic para PostgreS cambiar el estilo
Taller # 1 Uso y Manejo l Sistema Gestor Bases Datos PostgreSQL Luis García Computación ldgarc@gmail.com Contenido - Creación Tablas (Create Table...) ( Check Foreign Keys ) - Inserción Datos (Insert Into...)
Más detallesSon objetos cuya función es el tratamiento de varios registros exclusivamente durante la ejecución de un programa.
TABLAS INTERNAS Qué son? Cuando desde un programa realizamos una consulta en Base de Datos a través de sentencias SQL, solemos requerir que los resultados se guarden en alguna estructura de nuestro programa,
Más detallesUNIVERSIDAD DEL ISTMO CAMPUS IXTEPEC LIC. INFORMATICA GRUPO 508 PROCEDIMIENTOS ALMACENADOS EN SQL SERVER 2000
PROCEDIMIENTOS ALMACENADOS EN SQL SERVER 2000 Creación de la base de Datos Pulsamos F5 para Actualizar, y una vez posicionados en nuestra base de datos,se crean los scripts que seran soportados por el
Más detallesSQL EMBEBIDO FELIPE GARCÍA GÓMEZ
UNIVERSIDAD DE CASTILLA-LA MANCHA ESCUELA SUPERIOR DE INFORMÁTICA SQL EMBEBIDO FELIPE GARCÍA GÓMEZ Profesor: Asignatura: Titulación: Fecha: D. Francisco Ruiz González Bases de Datos Ing. Sup. Informática
Más detallesOPTIMIZACIÓN DE CONSULTAS EN SQL. Análisis de Consultas y Transacciones Ajuste de Indices Ajuste de Consultas
OPTIMIZACIÓN DE CONSULTAS EN SQL Análisis de Consultas y Transacciones Ajuste de Indices Ajuste de Consultas Análisis de Consultas y Transacciones Para elaborar el diseño físico de la base de datos debemos
Más detallesSintaxis: CURSOR nombre_cursor[(param1 [IN] tipo1,... )] IS consulta ;
7. CONCEPTOS AVANZADOS DE CURSORES EXPLICITOS En este capítulo veremos algunas cosas bastante útiles respecto a los cursores explícitos, como pueden ser los cursores con parámetros (que nos permitirán
Más detalles5- Uso de sentencias avanzadas
Objetivos: 5- Uso de sentencias avanzadas Elaborar sentencias de manejo de datos. Recursos: Microsoft SQL Server Management Studio Guías prácticas. Introducción: Después de trabajar con las sentencias
Más detallesLaboratorio Informix. Stored Procedures Triggers
Laboratorio Informix Stored Procedures Triggers Repaso A partir del ER, hicimos las tablas de la base de datos. Creamos en MySql las base de datos y las tablas Hicimos una aplicación que se comunica con
Más detallesCONSULTAS CON SQL. 3. Hacer clic sobre el botón Nuevo de la ventana de la base de datos. Aparecerá el siguiente cuadro de diálogo.
CONSULTAS CON SQL 1. Qué es SQL? Debido a la diversidad de lenguajes y de bases de datos existentes, la manera de comunicar entre unos y otras sería realmente complicada a gestionar de no ser por la existencia
Más detalles6- Combinación de tablas
Objetivos: 6- Combinación de tablas Utiliza sentencias para unir los datos de diferentes tablas. Recursos: Microsoft SQL Server Management Studio Guías prácticas. Script de bases de datos. Introducción
Más detallesRepaso de Conceptos Básicos de Bases de Datos
escuela técnica superior de ingeniería informática Repaso de Conceptos Básicos de Bases de Datos Departamento de Lenguajes Grupo de Ingeniería del Software Septiembre 2004 Definición Una base de datos
Más detallesOracle Básico PL/SQL
Oracle Básico PL/SQL Creación de un Esquema de Base de Datos El objetivo de este ejercicio es la ejecución de sentencia SQL de tipo DDL. Contenido Caso a Desarrollar...2 Modelo Lógico... 2 Modelo Físico...
Más detallesBase de Datos Práctica 1.
Base de Datos Práctica 1. Objetivo: Introducción al Mysql, aprender a identificar los errores más comunes en la creación de las bases de datos para su solución, conocer los diferentes tipos de datos y
Más detallesAUTENTICACIÓN: DETERMINAR SI EL USUARIOS ES QUIÉN DICE SER AUTORIZACIÓN: DETERMINA A CUÁLES OBJETOS TIENE ACCESO EL USUARIO
AUTENTICACIÓN Y AUTORIZACIÓN (L17) AUTENTICACIÓN: DETERMINAR SI EL USUARIOS ES QUIÉN DICE SER AUTORIZACIÓN: DETERMINA A CUÁLES OBJETOS TIENE ACCESO EL USUARIO PG_HBA.CONF (L17) ARCHIVO pg_hba.conf PARA
Más detallesFormato para prácticas de laboratorio
Formato para prácticas de laboratorio CARRERA PLAN DE ESTUDIO CLAVE IGNATURA NOMBRE DE LA IGNATURA LSC 2009-2 12001 Administración de Bases de Datos PRÁCTICA No. 5 LABORATORIO DE NOMBRE DE LA PRÁCTICA
Más detallesBases de Datos SQL 1 SQL. Jorge Pérez R. Universidad de Talca, II Semestre 2006
Bases de Datos SQL 1 SQL Jorge Pérez R. Universidad de Talca, II Semestre 2006 Bases de Datos SQL 2 SQL + Procedural La mayoría de los DBMS actuales permiten extensiones de SQL para la creación de bloques
Más detallesBase de Datos Distribuidas Lic. Hugo D. Ramón Conceptos de Bases de Datos Agenda Algebra Relacional Cálculo Relacional Conceptos Fundamentales de Base de Datos SQL 0/09/007 Conceptos de Bases de Datos
Más detallesÍNDICE. Introducción... Capítulo 1. Novedades de Access 2013... 1
Introducción... XIII Capítulo 1. Novedades de Access 2013... 1 Nuevas posibilidades de cifrado, compactación y reparación de archivos... 1 Trabajo en la nube... 2 Compartir la información... 3 Guardar
Más detallesProgramación SQL. Lucio Salgado Diciembre 2008
Programación SQL Lucio Salgado Diciembre 2008 1 Gestionadores de Bases de Datos (DBMS) Es el software que permite administrar bases de datos, a través de ella el usuario puede usar los datos con mucha
Más detallesCONSULTAS MULTITABLAS SQL SERVER 2005. Manual de Referencia para usuarios. Salomón Ccance CCANCE WEBSITE
CONSULTAS MULTITABLAS SQL SERVER 2005 Manual de Referencia para usuarios Salomón Ccance CCANCE WEBSITE CONSULTAS MULTITABLAS Hasta ahora hemos visto consultas que obtienen los datos de una sola tabla,
Más detallesTRANSACT-SQL, DISEÑO Y PROGRAMACIÓN DE BASES DE DATOS EN SQL SERVER 2008
TRANSACT-SQL, DISEÑO Y PROGRAMACIÓN DE BASES DE DATOS EN SQL SERVER 2008 ESTRUCTURA DEL SEMINARIO Modulo 1: Crear y administrar una base de datos SQL Server Métodos para crear una base de datos SQLServer.
Más detallesUNIDAD 1.- PARTE 1 MANIPULACIÓN AVANZADA DE DATOS CON SQL. BASES DE DATOS PARA APLICACIONES. Xochitl Clemente Parra Armando Méndez Morales
UNIDAD 1.- PARTE 1 MANIPULACIÓN AVANZADA DE DATOS CON SQL. BASES DE DATOS PARA APLICACIONES Xochitl Clemente Parra Armando Méndez Morales Práctica preliminar Crear la siguiente base de datos de prácticas
Más detallesIntroducción al álgebra relacional. Con ejemplos en SQL
OpenStax-CNX module: m18351 1 Introducción al álgebra relacional. Con ejemplos en SQL Miguel-Angel Sicilia This work is produced by OpenStax-CNX and licensed under the Creative Commons Attribution License
Más detallesEsta extensión está obsoleta a partir de PHP 5.5.0, y será eliminada en el futuro
USAR MYSQL EN PHP PHP tiene una librería de funciones nativas para conectarse a las base de datos MySQL. Por un lado reconoce la librería mysql y por otro mysqli. Se recomienda el uso de mysqli dado que
Más detallesOtros objetos de Base de Datos
Maestría en Bioinformática Bases de Datos y Sistemas de Información Otros objetos de Base de Datos Ing. Alfonso Vicente, PMP alfonso.vicente@logos.com.uy Agenda Secuencias Triggers Vistas Código almacenado
Más detallesRepaso. Laboratorio Informix. Stored Procedures. Ejemplo. Creación de stored procedures. Sql en un Procedimiento
Laboratorio Informix Stored Procedures Triggers Repaso A partir del ER, hicimos las tablas de la base de datos. Creamos en MySql las base de datos y las tablas Hicimos una aplicación que se comunica con
Más detallesUn ejemplo teórico de trigger podría ser éste:
9. TRIGGERS EN LA BASE DE DATOS Un trigger (disparador sería la traducción técnica) es un bloque PLSQL que se ejecuta implícitamente cuando ocurre un evento y pueden ser de base de datos o de aplicación.
Más detallesTEMA 20: CONCEPTOS BÁSICOS DE SQL
TEMA 20: CONCEPTOS BÁSICOS DE SQL OBJETIVOS DEL TEMA Introducción al lenguaje de consultas SQL. Para iniciar esta parte del curso se va a utilizar el programa SQLITE que es sencillo, multiplataforma y
Más detallesEL LENGUAJE DE BASES DE DATOS SQL (DDL, DML, TRIGGERS Y STORE PROCEDURES)
EL LENGUAJE DE BASES DE DATOS SQL (DDL, DML, TRIGGERS Y STORE PROCEDURES) Por qué son importantes las Bases de Datos? Las Bases de Datos son el método preferido para el almacenamiento estructurado de datos.
Más detallesOracle 12c DISEÑO Y PROGRAMACIÓN
Oracle 12c Se estudia el servidor de bases de datos empresarial Oracle 12c, centrándose especialmente en el punto de vista de un diseñador o programador de bases de datos, pero explicando también cómo
Más detallesTemario Curso Bases de Datos
Temario Curso Bases de Datos TEMA 1. INTRODUCCION A LAS BASES DE DATOS 1. Cualidades De La Información 2. Sistemas de Información 2.1. Componentes de un Sistema de Información 3. Niveles de Gestión de
Más detallesBase de datos Procedimientos Almacenados y Funciones
Base de datos Procedimientos Almacenados y Eduardo Saavedra A. Universidad Nacional Andrés Bello 4 de noviembre de 2008 Contenidos Ventajas 1 Ventajas 2 3 4 5 Conceptos Ejemplo 6 Procedimiento Almacenado
Más detallesBases de Datos / Elementos de Bases de Datos 2011. Que es un Stored Procedure? Stored Procedures: Ventajas
Bases de Datos / Elementos de Bases de Datos 2011 Stored Procedures, Triggers y Transacciones en MySQL Departamento de Ciencias e Ingeniería de la Computación Universidad Nacional del Sur 1 Que es un Stored
Más detallesQUÉ ES UNA BASE DE DATOS Y CUÁLES SON LOS PRINCIPALES TIPOS? EJEMPLOS: MYSQL, SQLSERVER, ORACLE, POSTGRESQL, INFORMIX (DV00204A)
APRENDERAPROGRAMAR.COM QUÉ ES UNA BASE DE DATOS Y CUÁLES SON LOS PRINCIPALES TIPOS? EJEMPLOS: MYSQL, SQLSERVER, ORACLE, POSTGRESQL, INFORMIX (DV00204A) Sección: Divulgación Categoría: Lenguajes y entornos
Más detallesSub consultas avanzadas
Sub consultas avanzadas Objetivo Después de completar este capítulo conocerá lo siguiente: Escribir una consulta de múltiples columnas Describir y explicar el comportamiento de las sub consultas cuando
Más detallesAsignatura: Administración de Bases de Datos. Pedro P. Alarcón Cavero
Ingeniería Técnica en Informática Escuela Universitaria de Informática Universidad Politécnica de Madrid Asignatura: Administración de Bases de Datos Tema 5: Proceso de Transacciones Pedro P. Alarcón Cavero
Más detalles