OR true null false true true true true null true null null false true null false NOT

Dimensione: px
Iniziare la visualizzazioe della pagina:

Download "OR true null false true true true true null true null null false true null false NOT"

Transcript

1 Il linguaggio SQL è un linguaggio standard per la definizione, manipolazione e interrogazione delle basi di dati relazionali ed ha le seguenti caratteristiche: è dichiarativo; opera su multiset di tuple, ossia su insiemi di tuple che possono contenere duplicati; consente di tradurre tutte le interrogazioni esprimibili in algebra relazionale; L'SQL mette a disposizione 6 tipi di dati: 1. Caratteri: Char (x) > caratteri a lunghezza fissa stabilita da x; Varchar (x) > caratteri a lunghezza variabile, con lunghezza max stabilita da x; 2. Bit: è i Booleano, che consente che assume valori 0 o 1 (vero o falso); 3. Numerico esatto: Interi: Integer (o semplicemente Int) e Smallint; Decimali: Decimal, dove bisogna specificare anche la precisione e la scala; 4. Numerico Approssimato: Float dove bisogna specificare la precisione; Real; Double Precision; 5. Datatime: Date: AAAA MM GG Time: OO MM SS TimeStamp: AAAA MM GG OO MM SS 6. Intervallo: Interval, nel quale bisogna indicare il campo iniziale e finale ES: Interval year (2) to month Il valore 2 indica il numero massimo di campi consentiti in year, ossia questo intervallo varia da 0 anni e 0 mesi, fino a 99 anni e 11 mesi ES: Interval year (5) to month Il valore 5 indica il numero massimo di campi consentiti in year, ossia questo intervallo varia da 0 anni e 0 mesi, fino a anni e 11 mesi Per consentire i valori nulli, l'sql utilizza una logica a 3 valori basata sulle seguenti tabelle: AND true null false true true null false null null null false false false false false OR true null false true true true true null true null null false true null false NOT true null false false null true

2 dove: un qualsiasi confronto con il valore null restituisce ancora nulli (ES: X <op> null = null [dove <op> è un operatore algebrico o relazionale e X è una costante o una variabile]); due valori null sono considerati diversi; due valori null sono considerati uguali solo ai fini dell'indicizzazione e ai fini del raggruppamento; Schema: è una collezione di oggetti del database (tabelle, domini, indici, viste, ecc...). Tutti gli oggetti dello schema hanno lo stesso proprietario. CREATE SCHEMA [<nome_schema>] [AUTHORIZATION <nome_proprietario>] Dove: se AUTHORIZATION <nome_proprietario> viene omesso, si considera come proprietario colui che ha dato il comando; se <nome_schema> viene omesso, si assume come nome dello schema, quello del proprietario; la dichiarazione degli oggetti dello schema può avvenire al di fuori del comando CREATE SCHEMA; Tabella: è costituita da una collezione ordinata (lista) di uno o più attributi (colonne) e da un insieme di zero o più vincoli. CREATE TABLE <nome_tabella> (<nome_colonna> <dominio> [<vincolo_di_colonna>],..., <nome_colonna> <dominio> [<vincolo_di_colonna>], [<vincolo_di_tabella>]) Domini: è un insieme di valori consentiti. Un dominio può essere di tipo di base del SQL oppure può essere definito dall'utente. CREATE DOMAIN <nome_dominio> AS <tipo_di_dati> [<valore_default>] [<vincolo_di_dominio>] Indici: i comandi di definizione degli indici, non fanno parte dello standard del linguaggio Sintassi generalmente accettata: CREATE [UNIQUE] INDEX <nome_indice> ON <tabella> (<lista_colonne>) NB: inserendo UNIQUE dico che non sono consentiti valori duplicati degli attributi specificati in <lista_colonne>, ossia è come se dichiarassi <lista_colonne> come chiave di <tabella> Rimozione: è possibile rimuovere le tabelle, e gli schemi creati. DROP SCHEMA <nome_schema> DROP TABLE <nome_tabella>

3 Vincoli di Tabella: permettono di controllare i valori che possono essere registrati in una tabella. Primary key: esprime la chiave primaria della tabella e può essere definita solo una volta nella tabella; PRIMARY KEY (<lista_colonne>) Foreign key: FOREIGN KEY (<lista_colonne>) REFERENCES <tabella> [(<lista_colonne>)] Dove: (<lista_colonne>) deve essere definita in <tabella> come chiave in assenza di (<lista_colonne>) è riferita alla primary key di <tabella> Check: esprime un generico vincolo sulla tabella tramite un'espressione che deve essere vera per tutte le tuple della tabella; CHECK (<condizione>) Vincoli di Colonna: permettono di controllare i valori che possono essere registrati in una singola colonna. Tutti i vincoli di colonna possono essere espressi come vincoli di tabella. Not Null: l'attributo non può assumere il valore null; Unique: esprime l'unicità dell'attributo. (Not Null Unique dichiara che l'attributo è una chiave della tabella); Primary key: stabilisce che l'attributo è la chiave primaria della tabella; References: esprime il vincolo delle FK, la colonna nella tabella riferita può essere la primary key oppure una colonna esplicitamente indicata; Check: esprime un generico vincolo sulla colonna tramite un'espressione logicorelazionale; Violazione di vincoli di integrità: quando il sistema rileva una violazione di vincoli di integrità, il comando di aggiornamento viene rifiutato e viene segnalato l'errore all'utente. FOREIGN KEY (<lista_colonne>) REFERENCES <tabella> [(<lista_colonne>)] ON <DELETE UPDATE> <CASCADE SET NULL SET DEFAULT NO ACTION> Una operazione sulla tabella che effettua il riconoscimento, detta dipendente, che viola il vincolo viene rifiutata. Ad una operazione sulla tabella riferita che viola il vincolo, si può rispondere con: Cascade: in caso di modifica, il nuovo valore dell'attributo della tabella riferita viene riportato su tutte le corrispondenti righe della tabella dipendente. In caso di cancellazione, tutte le righe della tabella dipendente corrispondenti alla riga cancellata vengono cancellate. Set Null: all'attributo referente viene assegnato il valore null al posto del valore modificato/cancellato nella tabella riferita. Set Default: all'attributo referente viene assegnato il valore di default al posto del valore modificato/cancellato nella tabella riferita. No Action: non viene eseguita alcuna reazione.

4 Modifica della struttura di una tabella Il comando ALTER TABLE <nome tabella> <tipo modivica> permette di modificare la struttura di una tabella. In <tipo modivica> si possono specificare le seguenti azioni: Aggiunta di una colonna: ADD [COLUMN] <nome colonna> <dominio> [<vincolo di colonna>] Rimozione di una colonna: DROP [COLUMN] <nome colonna> RESTRICT CASCADE Con RESTRICT la colonna viene eliminata solo se non ci sono dipendenze da tali colonne in altre definizioni, mentre con CASCADE si forza l'eliminazione della colonna e di tutte le dipendenze nelle altre definizioni. Aggiunta di un vincolo di tabella: ADD <vincolo di tabella> Rimozione di un vincolo di tabella: DROP <nome vincolo> RESTRICT CASCADE Con RESTRICT un vincolo di unicità non viene eliminato se è usato un vincolo di foreing key, mentre con CASCADE si forza l'eliminazione anche del vincolo di foreing key. Imposta e il valore di default di una colonna: ALTER [COLUMN] <nome colonna> SET DEFAULT <valore> Annulla il valore di default per una colonna: ALTER [COLUMN] <nome colonna> DROP DEFAULT Il comando ALTRE DOMAIN <nome dominio> <tipo modifica> permette di modificare alcune proprietà di un dominio di valori. Le proprietà modificabili sono quelle che non influenzano i dati reali. Interrogazioni L'istruzione base dell SQL per costruire interrogazioni di complessità arbitraria è lo statement SELECT Sintassi di base: SELECT [DISTINCT ALL] <lista select> FROM <list from> [WHERE <condizione>] [ORDER BY <lista order>] Dove: con ALL (default) non c'è l'eliminazione dei duplicati, mentre con DISTINCT gli è l'eliminazione dei duplicati, ossia non è necessaria se in SELECT inserisco una chiave primaria 1. <lista select> uno o più attributi della lista from; funzioni aggregate: COUNT, AVG, MIN, MAX, SUM; costanti; una generica espressione matematica che coinvolge uno o più di te gli oggetti precedenti; il simbolo *: tutti gli attributi;

5 2. <lista from> una o più tabelle o viste; operazioni di join tra una o più tabelle o viste; 3. <condizione>: predicati semplici; predicati di join; predicati di subquery; 4. <lista order>: uno o più attributi della <lista select> ordine ascendente (default) o discendente (DESC) Predicati semplici Operatori relazionali: <attr> <op rel> <cost> Dove <op rel> appartiene a uno dei seguenti simboli: =, < >, >, > =, <, <= Operatore di range: <attr> BEETWIN <cost1> AND <cost2> Operatore dei set: <attr> IN (<cost1>,, <costn>) Operatore di confronto stringhe: <attr> LIKE <stringa> Dove <stringa> può contenere i caratteri speciali _ (carattere arbitrario) e % (stringa arbitraria) Operatori quantificati: <attr> <op rel> [ANY ALL] (<cost1>,, <costn>) Confronto con le si era vuoto (): <attr> <op rel> ANY () ha valore false <attr> <op rel> ALL () ha valore true Operatore di confronto con valori NULL: <attr> IS [NOT] NULL Ordinamento del risultato: l'ordinamento deve essere fatto rispetto a uno o più elementi della <lista select> con tale elemento può essere indicato anche riportando la sua posizione nella <lista select> Esempio: SELECR Matr, CC, (60*Voto)/30 WHERE CC= C1 ORDER BY 3 DESC, Matr ossia ordina secondo la terza colonna della lista di selezione, cioè (60*Voto)/30 Prodotto cartesiano e Join Il prodotto cartesiano di due o più relazioni si ottiene riportando le relazioni nella <lista select> della clausola FROM, senza clausola WHERE. Il Join viene espresso generalmente riportando nella clausola FROM le relazioni interessate e nella clausola WHERE le condizioni di join. Con l SQL 92 è possibile esprimere le operazioni di join nella clausola FROM: <tabella1> [INNER LEFT RIGHT FULL] JOIN <tabella2> ON <condizione> Il default è il join interno, quindi la parola INNER può essere commessa.

6 Outer join: oltre al join interno, con lo standard SQL 92 sono stati introdotti gli operatori di outer join: <tabella1> LEFT JOIN <tabella2> ON <condizione> mantiene le tuple le di <tabella1> per cui non esiste corrispondenza in <tabella2> <tabella1> RIGHT JOIN <tabella2> ON <condizione> mantiene le tutte le di <tabella2> per cui non esiste corrispondenza in <tabella1> <tabella1> FULL JOIN <tabella2> ON <condizione> mantiene le tutte le di <tabella1> e di <tabella2> per cui non esiste corrispondenza in <tabella2> e <tabella1> rispettivamente. Le tuple senza corrispondenza vengono concatenate con tuple di valori null, di lunghezza opportuna. Nella clausola FROM è possibile esprimere più di un'operazione di JOIN. Esempio: per ogni esame con voto superiore a 24 per riportare il nome dello studente e il codice del docente del corso. SELECT S.SNome, C.CD FROM (S JOIN E ON (S.Matr=E.Matr)) JOIN C ON (E.CC=C.CC) WHERE Voto > 24 Oppure SELECT S.SNome, C.CD, E, C WHERE S.Matr = E.Matr AND E.CC = C.CC AND Voto > 24 Self join: nel join tra una tabella e se stessa occorre necessariamente utilizzare dei sinonimi (alias) per distinguere le diverse corrispondenze della tabella. Esempio: coppie di studenti residenti nella stessa città SELECT S1.Matr, S2.Matr S1, S S2 WHERE S1..Città = S2.Città AND S1.Matr < S2.Matr Interrogazioni innestate: viene detta innestata o nidificata se la sua condizione è formulata usando il risultato di un'altra interrogazione chiamata subquery. In generale, un'interrogazione innestata viene formulata con: operatori quantificati: <attr> <op rel> [ANY ALL] (<subquery>) N.B.: se uso ALL devo usare sempre o >= o <=; operatore di set: <attr> [NOT] IN (<subquery>) N.B.: NOT IN è la sottrazione; operatore esistenziale: [NOT] EXISTS (<subquery>)

7 Interrogazione innestata con operatori quantificati il confronto tra un attributo e il risultato di un'interrogazione, <attr> <op rel> (<subquery>) non è in generale corretto in quanto si confronta il singolo valore assunto da <attr> con le insieme di valori restituiti da <subquery>. Tuttavia, il confronto è possibile quando <subquery> produce (run time) un valore atomico. Nel confronto tra un attributo e il risultato di una interrogazione occorre specificare, dopo l'operatore relazionale <op rel>, ANY oppure ALL. Esempio: studenti con anno di corso più basso SELECT * WHERE ACorso <= ALL (SELECT ACorso ) Subquery correlate: una subquery viene detta correlata se la sua condizione è formulata usando relazioni e/o sinonimi definiti nella query esterna. Esempio: nome degli studenti che hanno sostenuto l'esame del corso C1 SELECT SNome WHERE C1 IN (SELECT CC WHERE E.Matr = S.Matr) per una maggiore leggibilità è conveniente fare uso di sinonimi. SELECT S1.SNome S1 WHERE C1 IN (SELECT CC E1 WHERE E1.Matr = S1.Matr) I sinonimi sono indispensabili quando una stessa relazione compare sia nelle query e esterna che nella subquery (analogamente alla self join). Per gli attributi non quantificati avviene la quantificazione automatica con il nome della relazione più vicina, ad esempio la precedente interrogazione si può scrivere come: SELECT Città, SNome S1 WHERE S1.ACorso >= ALL (SELECT A.Corso WHERE S1.Città=Città) Il quantificatore esistenziale Il predicato EXISTS (<subquery>) ha valore true sé e solo se le insieme di valori restituiti da (<subquery>) è non vuoto. Esempio: nome degli studenti che hanno sostenuto l'esame del corso C1 SELECT SNome WHERE EXISTS (SELECT * WHERE E.Matr = S.Matr AND E.CC = C1 ) Il predicato NOT EXISTS (<subquery>) ha valore true sé e solo se le insieme dei valori restituiti da (<subquery>) è vuoto.

8 Esempio: nome degli studenti che hanno sostenuto l'esame del corso C1 SELECT SNome WHERE NOT EXISTS (SELECT * WHERE E.Matr = S.Matr AND E.CC = C1 ) Generalmente, al fine di formulare query significative con EXISTS è indispensabile utilizzare subquery correlate. Riduzioni di query innestate Le query innestate formulate con i seguenti operatori si possono ridurre a query semplici equivalenti (stessa risposta per ogni possibile istanza delle basi di dati): IN ANY (con qualsiasi operatore di confronto) EXISTS (con subquery correlata) Le query innestate formulate con i seguenti operatori non si possono ridurre: NOT IN NOT ANY (con qualsiasi operatore di confronto) NOT EXISTS (con subquery correlata) Funzioni aggregate SQL mette a disposizione una serie di funzioni per elaborare i valori di un attributo (MAX, MIN, AVG, SUM) e per contare le tutte le che soddisfano una condizione (COUNT). Opzioni: *: conteggio del numero di righe (COUNT) ALL: trascura i null (COUNT, AVG, SUM); (default) DISTINCT: trascura i null ed elimina i duplicati (COUNT, AVG, SUM) Non è l'è città la presenza contemporanea nella <lista select> di nomi di campi e funzioni aggregate, pertanto la seguente interrogazione non è corretta: SELECT Matr, MAX (Voto) Raggruppamento: la clausola GROUP BY In una distruzione SELECT è possibile formare dei gruppi di tuple che hanno lo stesso valore di specificati attributi, tramite la clausola GROUP BY: SELECT [DISTINCT ALL] <lista select> FROM <lista from> [WHERE <condizione>] [GROUP BY <lista group>] Il risultato della SELECT è un unico record per ciascun gruppo: pertanto nella <lista select> possono comparire solo: uno o più attributi di raggruppamento, cioè specificati in <lista group> funzioni aggregate: tali funzioni vengono valutate, e quindi forniscono un valore unico, per ciascun gruppo

9 Raggruppamento: la clausola HAVING La clausola HAVING è equivalente alla clausola WHERE applicata a gruppi di tuple: ogni gruppo costruito tramite GROUP BY fa parte del risultato dell'interrogazione solo se il predicato specificato nella clausola HAVING risulta soddisfatto. [GROUP BY <lista group>] [HAVING <condizione>] Il predicato espresso nella clausola HAVING è formulato utilizzando uno o più attributi specificati in <lista group> funzioni aggregate Unione, differenza, intersezione Unione: <subquery> UNION [ALL] <subquery> Differenza: <subquery> EXCEPT [ALL] <subquery> Intersezione: <subquery> INTERSECTION [ALL] <subquery> Con ALL si considera la semantica del multiset (a, b) UNION ALL (a) = (a, a, b) (a, a) EXCEPT ALL (a) = (a) (a, a) INTERSECTION ALL (a, b) = (a, a) Le interrogazioni formulate tramite gli operatori EXCEPT e INTERSECTION possono essere prescritte, in maniera equivalente, utilizzando operatori introdottoti in precedenza, (come ad esempio NOT IN e IN rispettivamente). Questo non è valido per l'operatore UNION. Anche per questo motivo generalmente nelle implementazioni di SQL l'unico degli operatori presenti è UNION. Divisione L'operazione di divisione non è definita il SQL. Pertanto, le interrogazioni che richiedono tale operatore, vengono in genere riformulate con una doppia negazione nel seguente modo: SELECT * WHERE NOT EXIST (SELECT * FROM C WHERE CD = D1 AND NOT EXIST (SELECT * WHERE E.Matr = S.Matr AND E.CC = C.CC))

10 Manipolazione dei dati Inserimento di record: inserimento esplicito di un singolo record: INSERT INTO <tabella> [<lista attr>] VALUES <lista valori> inserimento del risultato di una interrogazione: INSERT INTO <tabella> [<lista attr>] VALUES <subquery> dove i valori riportati in <lista valori> devono corrispondere in numero e tipo agli attributi specificati in <lista attr> e <lista attr> deve essere contenuta nella lista di attributi di <tabella>: i valori corrispondenti a gli attributi mancanti vengono posti uguali al valore di default oppure a null. Modifica di record: UPDATE <tabella> SET <attr> = <espressione> [WHERE <condizione>] Cancellazione di record: DELETE FROM <tabella> [WHERE <condizione>] Viste Una vista è una tabella " virtuale" definita, tramite un'interrogazione, da altre tabelle base o da altre viste. Le interrogazioni non vengono eseguite all atto di creazione della vista, ma quando la vista viene utilizzata. Esse vengono calcolate ogni volta che vengono chiamate, quindi sono sempre aggiornate. Le viste aggiornabili, sono possibili operazioni di modifica (INSERT, UPDATE, DELETE), tradotte in operazioni di modifica sulle tabelle base. In SQL una vista è aggiornabile solo quando una sola riga di ciascuna tabella di base corrisponde ad una riga della vista. In particolare, quindi non solo aggiornabili viste ottenute: Tramite GROUP BY e funzioni aggregate; Tramite DISTINCT senza inclusione di una chiave; Tramite riferimenti a viste non aggiornabili;

Basi di dati. Il Linguaggio SQL. K. Donno - Il Linguaggio SQL

Basi di dati. Il Linguaggio SQL. K. Donno - Il Linguaggio SQL Basi di dati Il Linguaggio SQL Data Definition Language (DDL) Data Definition Language: insieme di istruzioni utilizzate per modificare la struttura della base di dati Ne fanno parte le istruzioni di inserimento,

Dettagli

Definizione di domini

Definizione di domini Definizione di domini Come nei linguaggi ad alto livello (es. C) è possibile definire nuovi domini (tipi di dati) a partire da quelli predefiniti, anche se il costruttore è più limitato. create domain

Dettagli

Gestione delle tabelle

Gestione delle tabelle Linguaggio SQL: fondamenti Creazione di una tabella Modifica della struttura di una tabella Cancellazione di una tabella Dizionario dei dati Integrità dei dati 2 Creazione di una tabella (1/3) Si utilizza

Dettagli

Esercitazione query in SQL L esercitazione viene effettuata sul database viaggi e vacanze che prevede il seguente modello E/R:

Esercitazione query in SQL L esercitazione viene effettuata sul database viaggi e vacanze che prevede il seguente modello E/R: Esercitazione query in SQL L esercitazione viene effettuata sul database viaggi e vacanze che prevede il seguente modello E/R: Si consiglia di creare il data base, inserire i dati nelle tabelle, provare

Dettagli

SQL SQL. Definizione dei dati. Domini. Esistono 6 domini elementari:

SQL SQL. Definizione dei dati. Domini. Esistono 6 domini elementari: SQL SQL (pronunciato anche come l inglese sequel: acronimo di Structured Query Language (linguaggio di interrogazione strutturato Linguaggio completo che presenta anche proprietà di: DDL (Data Definition

Dettagli

DDL, VINCOLI D INTEGRITÁ, AGGIORNAMENTI E VISTE. SQL è più di un semplice linguaggio di interrogazione

DDL, VINCOLI D INTEGRITÁ, AGGIORNAMENTI E VISTE. SQL è più di un semplice linguaggio di interrogazione SQL DDL, VINCOLI D INTEGRITÁ, AGGIORNAMENTI E VISTE SQL è più di un semplice linguaggio di interrogazione! Linguaggio di definizione dati (Data-definition language, DDL):! Crea/distrugge/modifica relazioni

Dettagli

Il linguaggio SQL: query innestate

Il linguaggio SQL: query innestate Il linguaggio SQL: query innestate Sistemi Informativi L-A Home Page del corso: http://www-db.deis.unibo.it/courses/sil-a/ Versione elettronica: SQLc-subquery.pdf Sistemi Informativi L-A DB di riferimento

Dettagli

SQL Sintassi Dei Comandi

SQL Sintassi Dei Comandi SQL Sintassi Dei Comandi Di Roberto Aloi http://prof3ta.homeunix.org prof3ta@email.it Questo fascicolo è stato realizzato esclusivamente a fini divulgativi e per la libera consultazione. E' concessa la

Dettagli

Operazioni sui database

Operazioni sui database Operazioni sui database Le operazioni nel modello relazionale sono essenzialmente di due tipi: Operazioni di modifica della base di dati (update) Interrogazioni della base di dati per il recupero delle

Dettagli

Il linguaggio SQL. è di fatto lo standard tra i linguaggi per la gestione di data base relazionali.

Il linguaggio SQL. è di fatto lo standard tra i linguaggi per la gestione di data base relazionali. (Structured Query Language) : Il linguaggio è di fatto lo standard tra i linguaggi per la gestione di data base relazionali. prima versione IBM alla fine degli anni '70 per un prototipo di ricerca (System

Dettagli

Linguaggio SQL: fondamenti D B M G. Gestione delle tabelle

Linguaggio SQL: fondamenti D B M G. Gestione delle tabelle Linguaggio SQL: fondamenti Creazione di una tabella Modifica della struttura di una tabella Cancellazione di una tabella Dizionario dei dati Integrità dei dati 2 2007 Politecnico di Torino 1 Creazione

Dettagli

SQL (STRUCTURED QUERY LANGUAGE)

SQL (STRUCTURED QUERY LANGUAGE) SQL (STRUCTURED QUERY LANGUAGE) Prof. Nicoletta D Alpaos & Prof. Andrea Borghesan SQL DDL Data Definition Language DML Data Manipulation Language DCL Data Control Language DDL Obiettivo: Definire la struttura

Dettagli

Domini elementari, 2. Basi di dati. Domini elementari, 4. Domini elementari, 3. Domini definiti dagli utenti. Domini elementari, 5

Domini elementari, 2. Basi di dati. Domini elementari, 4. Domini elementari, 3. Domini definiti dagli utenti. Domini elementari, 5 Domini elementari, Basi di dati Linguaggi di Interrogazione: SQL Prof.Angela Bonifati Bit Valori booleani (vero/falso), singoli o in sequenza (la sequenza può essere di lunghezza variabile) Sintassi: bit

Dettagli

IL LINGUAGGIO SQL IDENTIFICATORI E TIPI DI DATI COMANDI E ISTRUZIONI

IL LINGUAGGIO SQL IDENTIFICATORI E TIPI DI DATI COMANDI E ISTRUZIONI IL LINGUAGGIO SQL Il linguaggio SQL ( Structured Query Languages) è un linguaggio non procedurale che è diventato uno standard tra i linguaggi per la gestione dei database relazionali. Il linguaggio procedurale

Dettagli

Basi di Dati e Sistemi Informativi. Structured Query Language

Basi di Dati e Sistemi Informativi. Structured Query Language Basi di Dati e Sistemi Informativi Structured Query Language Corso di Laurea in Ing. Informatica Ing. Gestionale Magistrale SQL come DDL e DML SQL non è solo un linguaggio di interrogazione Linguaggio

Dettagli

Giovanna Rosone 04/03/2010. 04/03/2010 SQL, Istruzioni per la modifica dello schema

Giovanna Rosone 04/03/2010. 04/03/2010 SQL, Istruzioni per la modifica dello schema Giovanna Rosone 04/03/2010 04/03/2010 SQL, Istruzioni per la modifica dello schema 1 Riepilogo Impiegato Pagamenti Nome colonna PAG_COD PAG_MATR Tipo dati CHAR(6) CHAR(6) Nome colonna Tipo dati PAG_STIPENDIO

Dettagli

----------------------------------------------------------------------------

---------------------------------------------------------------------------- APPUNTI DI SQL Gli appunti qui forniti vogliono essere un riferimento scritto di alcuni degli argomenti trattati a lezione per gli studenti a cui vengono messi a disposizione. Non viene fornita alcuna

Dettagli

Basi di Dati: Corso di laboratorio

Basi di Dati: Corso di laboratorio Basi di Dati: Corso di laboratorio Lezione 2 Raffaella Gentilini 1 / 45 Sommario 1 Il DDL di SQL: Cancellazione ed Aggiornamento di una BD Cancellazione di Schemi, Tabelle, e Domini Aggiornamento di Tabelle

Dettagli

Storia. Corso di Basi di Dati Spaziali. Componente DDL. Funzionalità. Esempio. Creazione di schema. Linguaggi: SQL. Storia:

Storia. Corso di Basi di Dati Spaziali. Componente DDL. Funzionalità. Esempio. Creazione di schema. Linguaggi: SQL. Storia: Corso di Basi di Dati Spaziali Linguaggi: SQL Angelo Montanari Donatella Gubiani Storia Storia: 1974: prima proposta SEQUEL 1981: prime implementazioni 1983: standard di fatto 1986, 1989, 1992 e 1999:

Dettagli

Documentazione SQL. Argomento Sintassi Note Definizione schema create schema [NomeSchema] [[authorization] Autorizzazione] {DefElementoSchema}

Documentazione SQL. Argomento Sintassi Note Definizione schema create schema [NomeSchema] [[authorization] Autorizzazione] {DefElementoSchema} Documentazione SQL Argomento Sintassi Note Definizione schema create schema [NomeSchema] [[authorization] Autorizzazione] {DefElementoSchema} Definizione tabella Definizione dominio Specifica di valori

Dettagli

Istruzioni DML di SQL

Istruzioni DML di SQL Istruzioni DML di SQL Pag. 99 par.4 1 Sintassi: Costrutto: INSERT INTO (Inserimento di dati in tabelle) INSERT INTO [(, ,, )] VALUES (, ,

Dettagli

Laboratorio di Basi di Dati e Web

Laboratorio di Basi di Dati e Web Laboratorio di Basi di Dati e Web Docente: Alberto Belussi Lezione 1 SQL Structured Query Language SQL è stato definito nel 1973 ed è oggi il linguaggio più diffuso per i DBMS relazionali Il linguaggio

Dettagli

SQL: concetti base SQL. Definizione dei dati in SQL. SQL: "storia"

SQL: concetti base SQL. Definizione dei dati in SQL. SQL: storia SQL SQL: concetti base originariamente "Structured Query Language", ora "nome proprio" linguaggio con varie funzionalità: contiene sia il DDL sia il DML ne esistono varie versioni vediamo gli aspetti essenziali,

Dettagli

SQL - Tipi di dato Il linguaggio SQL

SQL - Tipi di dato Il linguaggio SQL SQL - Tipi di dato Il linguaggio SQL I tipi di dato in SQL:1999 si suddividono in tipi predefiniti tipi strutturati tipi user-defined ci concentreremo sui tipi predefiniti i tipi predefiniti sono suddivisi

Dettagli

Il linguaggio SQL. Il linguaggio SQL. Il linguaggio SQL. SQL - Tipi di dato. SQL - Tipi di dato numerici. SQL - Tipi di dato numerici

Il linguaggio SQL. Il linguaggio SQL. Il linguaggio SQL. SQL - Tipi di dato. SQL - Tipi di dato numerici. SQL - Tipi di dato numerici Il linguaggio SQL Il linguaggio SQL il linguaggio SQL è un linguaggio per la definizione e la manipolazione dei dati, sviluppato originariamente presso il laboratorio IBM a San Jose (California) è diventato

Dettagli

MAX, SUM, AVG, COUNT)

MAX, SUM, AVG, COUNT) INTRODUZIONE A SQL Definizione di tabelle e domini Alcuni vincoli di integrità Struttura base SELECT FROM WHERE Funzioni di aggregazione (MIN, MAX, SUM, AVG, COUNT) Query da più tabelle (FROM R1, Rk) Join

Dettagli

SQL. Alcune note sulla definizione dei dati

SQL. Alcune note sulla definizione dei dati SQL Alcune note sulla definizione dei dati Domini Domini elementari (predefiniti) Domini definiti dall'utente (riutilizzabili, possono servire per specificare vincoli di dominio propri di una certa applicazione)

Dettagli

Join in SQL (primo modo) Informatica. Tabella Dipartimento. Interrogazione 4a. Interrogazione 4b. Interrogazione 4a

Join in SQL (primo modo) Informatica. Tabella Dipartimento. Interrogazione 4a. Interrogazione 4b. Interrogazione 4a Join in SQL (primo modo) Informatica Lezione 7 Laurea magistrale in Psicologia Laurea magistrale in Psicologia dello sviluppo e dell'educazione Anno accademico: 09- Per formulare interrogazioni che coinvolgono

Dettagli

Il linguaggio SQL: DDL di base

Il linguaggio SQL: DDL di base Il linguaggio SQL: DDL di base Sistemi Informativi T Versione elettronica: 04.1.SQL.DDLbase.pdf SQL: caratteristiche generali SQL (Structured Query Language) èil linguaggio standard de facto per DBMS relazionali,

Dettagli

Basi di dati SQL. Standardizzazione di SQL. Linguaggi di Interrogazione: SQL. Prof.Angela Bonifati

Basi di dati SQL. Standardizzazione di SQL. Linguaggi di Interrogazione: SQL. Prof.Angela Bonifati Basi di dati Linguaggi di Interrogazione: SQL Prof.Angela Bonifati 1 SQL Il nome stava per Structured Query Language Più che un semplice linguaggio di query: si compone di una parte DDL e di una DML DDL:

Dettagli

DBMS (Data Base Management System)

DBMS (Data Base Management System) Cos'è un Database I database o banche dati o base dati sono collezioni di dati, tra loro correlati, utilizzati per rappresentare una porzione del mondo reale. Sono strutturati in modo tale da consentire

Dettagli

SQL e ACCESS. Modello relazionale PROBLEMA ENTITA STUDENTE

SQL e ACCESS. Modello relazionale PROBLEMA ENTITA STUDENTE SQL e ACCESS Prof. Salvatore Multazzu (salvatoremultazzu@tiscali.it) Applicazioni Informatiche nella comunicazione Modello relazionale Entità Record o Ennuple Attributi o Campi Tipi Chiavi Primarie (PK)

Dettagli

Laboratorio di Basi di Dati

Laboratorio di Basi di Dati Laboratorio di Basi di Dati Docente: Alberto Belussi Lezione 1 SQL SQL (Structured Query Language) è stato definito nel 1973 ed è oggi il linguaggio più diffuso per i DBMS relazionali. Sono stati proposti

Dettagli

User Tools: DataBase Manager

User Tools: DataBase Manager Spazio di lavoro Per usare T-SQL Assistant selezionare il link Simple Query e spostare a piacere la piccola finestra dove un menu a tendina mostra i diversi comandi SQL selezionabili, il pulsante Preview

Dettagli

Corso di Laboratorio di Basi di Dati

Corso di Laboratorio di Basi di Dati Corso di Laboratorio di Basi di Dati F1I072 - INF/01 a.a 2009/2010 Pierluigi Pierini Technolabs S.p.a. Pierluigi.Pierini@technolabs.it Università degli Studi di L Aquila Dipartimento di Informatica Technolabs

Dettagli

Vincoli di Integrità Approccio dichiarativo alla loro implementazione

Vincoli di Integrità Approccio dichiarativo alla loro implementazione Vincoli di Integrità Approccio dichiarativo alla loro implementazione Antonella Poggi Dipartimento di informatica e Sistemistica SAPIENZA Università di Roma Progetto di Applicazioni Software Anno accademico

Dettagli

SQL. Linguaggio di interrogazione per basi di dati relazionali. Relazione = tabella con attributi (a 1, a 2,, a n ): Funzionalità principali di SQL:

SQL. Linguaggio di interrogazione per basi di dati relazionali. Relazione = tabella con attributi (a 1, a 2,, a n ): Funzionalità principali di SQL: SQL Linguaggio di interrogazione per basi di dati relazionali Relazione = tabella con attributi (a 1, a 2,, a n ): Funzionalità principali di SQL: Creazione delle tabelle Interrogazione della base di dati

Dettagli

SQL: Concetti Base -Prima Parte-

SQL: Concetti Base -Prima Parte- SQL: Concetti Base -Prima Parte- Atzeni, Ceri, Paraboschi, Torlone Basi Di Dati: Modelli e Linguaggi di Interrogazione, McGraw-Hill Italia Capitolo 4 SQL Structured Query Language Contiene: DDL (Data Definition

Dettagli

SQL (STRUCTURED QUERY LANGUAGE)

SQL (STRUCTURED QUERY LANGUAGE) SQL (STRUCTURED QUERY LANGUAGE) Prof. Nicoletta D Alpaos & Prof. Andrea Borghesan SQL DDL Data Definition Language DML Data Manipulation Language DCL Data Control Language DDL Obiettivo: Definire la struttura

Dettagli

Corso sul linguaggio SQL

Corso sul linguaggio SQL Corso sul linguaggio SQL Modulo L2B (SQL) 2.2 Comandi sulle tabelle 1 Prerequisiti Introduzione ai DB Tabelle, relazioni e attributi Chiave primaria Chiave esterna Vincoli di integrità 2 1 Introduzione

Dettagli

Abilità Informatiche A.A. 2010/2011 Lezione 9: Query Maschere Report. Facoltà di Lingue e Letterature Straniere

Abilità Informatiche A.A. 2010/2011 Lezione 9: Query Maschere Report. Facoltà di Lingue e Letterature Straniere Abilità Informatiche A.A. 2010/2011 Lezione 9: Query Maschere Report Facoltà di Lingue e Letterature Straniere Le QUERY 2 Che cos è una Query? Una Query rappresenta uno strumento per interrogare un database.

Dettagli

SQL -DDL. FONDISTA(Nome, Nazione, Età) GAREGGIA(NomeFondista, NomeGara, Piazzamento) GARA(Nome, Luogo, Nazione, Lunghezza)

SQL -DDL. FONDISTA(Nome, Nazione, Età) GAREGGIA(NomeFondista, NomeGara, Piazzamento) GARA(Nome, Luogo, Nazione, Lunghezza) 26/03/2013 SQL SQL -DDL Esercizio 4.3 Dare le definizioni SQL delle tre tabelle FONDISTA(Nome, Nazione, Età) GAREGGIA(NomeFondista, NomeGara, Piazzamento) GARA(Nome, Luogo, Nazione, Lunghezza) rappresentando

Dettagli

Il linguaggio SQL: le basi

Il linguaggio SQL: le basi Il linguaggio SQL: le basi Sistemi Informativi L-A Home Page del corso: http://www-db.deis.unibo.it/courses/sil-a/ Versione elettronica: SQLa-basi.pdf Sistemi Informativi L-A SQL: caratteristiche generali

Dettagli

Insegnamento di Informatica CdS Scienze Giuridiche A.A. 2006/7. Il trattamento dei dati

Insegnamento di Informatica CdS Scienze Giuridiche A.A. 2006/7. Il trattamento dei dati Insegnamento di Informatica CdS Scienze Giuridiche A.A. 2006/7 Il trattamento dei dati database: il linguaggio SQL seconda parte Prof. Valle D.ssa Folgieri Lez9 15.11.06 Trattamento dati. Database: il

Dettagli

SQL IL LINGUAGGIO DI INTERROGAZIONE

SQL IL LINGUAGGIO DI INTERROGAZIONE SQL IL LINGUAGGIO DI INTERROGAZIONE SQL! Originato da SEQUEL-XRM e System-R (1974-1977) dell IBM! Significato originario Structured Query Language! Standard de facto! Attuale standard ANSI/ISO è SQL:1999

Dettagli

ESEMPI DI QUERY SQL. Esempi di Query SQL Michele Batocchi AS 2012/2013 Pagina 1 di 7

ESEMPI DI QUERY SQL. Esempi di Query SQL Michele Batocchi AS 2012/2013 Pagina 1 di 7 ESEMPI DI QUERY SQL Dati di esempio... 2 Query su una sola tabella... 2 Esempio 1 (Ordinamento)... 2 Esempio 2 (Scelta di alcune colonne)... 3 Esempio 3 (Condizioni sui dati)... 3 Esempio 4 (Condizioni

Dettagli

Linguaggio SQL. Structured Query Language

Linguaggio SQL. Structured Query Language Linguaggio SQL Structured Query Language Creato negli anni 70 presso IBM Inizialmente solo linguaggio di interrogazione Ora linguaggio di riferimento per DB relazionali Standardizzato grazie al lavoro

Dettagli

Corso Sistemi Informativi Avanzati. Programma 30 set 2015. Installazione Macchina Virtuale. Introduzione alla BI nelle Aziende.

Corso Sistemi Informativi Avanzati. Programma 30 set 2015. Installazione Macchina Virtuale. Introduzione alla BI nelle Aziende. Programma 30 set 205 Installazione Macchina Virtuale Introduzione alla BI nelle Aziende Introduzione SQL Macchina Virtuale È un emulazione di un computer su un altro computer Stesso punto di partenza per

Dettagli

Il linguaggio SQL: viste e tabelle derivate

Il linguaggio SQL: viste e tabelle derivate Il linguaggio SQL: viste e tabelle derivate Sistemi Informativi L-A Home Page del corso: http://www-db.deis.unibo.it/courses/sil-a/ Versione elettronica: SQLd-viste.pdf Sistemi Informativi L-A DB di riferimento

Dettagli

SQL. Structured Query Language 1974: SEQUEL by IBM 1981: SQL by IBM 1986 1992: SQL ISO 9075:1992 SQL:1999 SQL:2003

SQL. Structured Query Language 1974: SEQUEL by IBM 1981: SQL by IBM 1986 1992: SQL ISO 9075:1992 SQL:1999 SQL:2003 SQL Structured Query Language 1974: SEQUEL by IBM 1981: SQL by IBM 1986 1992: SQL ISO 9075:1992 SQL:1999 SQL:2003 SQL Il linguaggio SQL è stato originariamente dichiarativo, diventando nel tempo sempre

Dettagli

DUE GRUPPI DI COMANDI

DUE GRUPPI DI COMANDI LEZIONE16 SQL DDL PAG. 1 / 9 PROF. ANDREA ZOCCHEDDU LEZIONE16 SQL DDL LINGUAGGIO SQL DATA DESCRIPTION LANGUAGE DUE GRUPPI DI COMANDI I comandi del linguaggio SQL sono divisi in due grandi gruppi che formano

Dettagli

SQL/OLAP. Estensioni OLAP in SQL

SQL/OLAP. Estensioni OLAP in SQL SQL/OLAP Estensioni OLAP in SQL 1 Definizione e calcolo delle misure Definire una misura significa specificare gli operatori di aggregazione rispetto a tutte le dimensioni del fatto Ipotesi: per ogni misura,

Dettagli

SQL. Storia e standard

SQL. Storia e standard SQL Lorenzo Sarti 2009 Basi di Dati 1 Storia e standard Lorenzo Sarti 2009 Basi di Dati 2 SQL-2 È ricco e complesso e nessun sistema commerciale lo implementa in maniera completa Sono definiti 3 livelli

Dettagli

Il linguaggio SQL: viste e tabelle derivate. Versione elettronica: SQLd-viste.pdf

Il linguaggio SQL: viste e tabelle derivate. Versione elettronica: SQLd-viste.pdf Il linguaggio SQL: viste e tabelle derivate Versione elettronica: SQLd-viste.pdf DB di riferimento per gli esempi Imp Sedi CodImp Nome Sede Ruolo Stipendio Sede Responsabile Citta E001 Rossi S01 Analista

Dettagli

Azioni. Select e join non consentono di modificare il contenuto del DB. Inserzione di nuovi dati. Azioni desiderate. Aggiornamento di dati

Azioni. Select e join non consentono di modificare il contenuto del DB. Inserzione di nuovi dati. Azioni desiderate. Aggiornamento di dati Azioni Select e join non consentono di modificare il contenuto del DB Azioni desiderate Inserzione di nuovi dati Aggiornamento di dati Cancellazione di dati Aggiunta di un record insert into utenti(nome,tel,codice_u)

Dettagli

Capitolo 4. Soluzione: Soluzione: Create domain STRING as character varying (256) default sconosciuto not null

Capitolo 4. Soluzione: Soluzione: Create domain STRING as character varying (256) default sconosciuto not null Capitolo 4 Esercizio 4.1 Ordinare i seguenti domini in base al valore massimo rappresentable, supponendo che integer abbia una rappresentazione a 32 bit e smallint a 16 bit: numeric(12,4), decimal(10),

Dettagli

Elementi di Algebra Relazionale

Elementi di Algebra Relazionale Note dalle lezioni di INFORMATICA (per gli allievi della classe quinta - indirizzo MERCURIO) Elementi di Algebra Relazionale prof. Stefano D.L.Campanozzi I.T.C. Giulio Cesare Bari - a.s. 2008-2009 1 Introduzione

Dettagli

INDICI. Prevediamo di effettuare spesso interrogazioni simili alle seguenti:

INDICI. Prevediamo di effettuare spesso interrogazioni simili alle seguenti: Date le tabelle: Clienti := < id, nome, cognome, indirizzo,città > Ordini := < id, data_ora_ordine, id_prodotto, id_cliente, quantità> Prodotti := < id, nome, descrizione, costo,scorte > INDICI Prevediamo

Dettagli

Data Base. Master "Bio Info" Reti e Basi di Dati Lezione 6

Data Base. Master Bio Info Reti e Basi di Dati Lezione 6 Data Base 1 Sommario I concetti fondamentali. Database Relazionale.. Query e SQL MySql, Creazione di un db in MySQL con PHPmyAdmin Creazione database e delle Tabelle Query Inserimento Ricerca Modifica

Dettagli

Vincoli di Integrità

Vincoli di Integrità Vincoli di Integrità Antonella Poggi Dipartimento di informatica e Sistemistica Sapienza Università di Roma Progetto di Applicazioni Software Anno accademico 2010-2011 Questi lucidi sono stati prodotti

Dettagli

Introduzione a MySQL

Introduzione a MySQL Introduzione a MySQL Cinzia Cappiello Alessandro Raffio Politecnico di Milano Prima di iniziare qualche dettaglio su MySQL MySQL è un sistema di gestione di basi di dati relazionali (RDBMS) composto da

Dettagli

SQL. Laboratorio di Progettazione di Basi di Dati (CdS in Informatica e TPS)

SQL. Laboratorio di Progettazione di Basi di Dati (CdS in Informatica e TPS) 1 SQL Laboratorio di Progettazione di Basi di Dati (CdS in Informatica e TPS) a.a. 2014/2015 http://www.di.uniba.it/~lisi/courses/basi-dati/bd2014-15.htm dott.ssa Francesca A. Lisi francesca.lisi@uniba.it

Dettagli

Volumi di riferimento

Volumi di riferimento Simulazione seconda prova Esame di Stato Gestione di un centro agroalimentare all ingrosso Parte prima) Un nuovo centro agroalimentare all'ingrosso intende realizzare una base di dati per l'attività di

Dettagli

SQL non è solo un linguaggio di interrogazione (Query Language), ma. Un linguaggio per la definizione di basi di dati (Data-definition language (DDL))

SQL non è solo un linguaggio di interrogazione (Query Language), ma. Un linguaggio per la definizione di basi di dati (Data-definition language (DDL)) SQL PER LA DEFINIZIONE DI BASI DI DATI 1 SQL non è solo un linguaggio di interrogazione (Query Language), ma Un linguaggio per la definizione di basi di dati (Data-definition language (DDL)) CREATE SCHEMA

Dettagli

PROGRAMMA DI CLASSE 5AI

PROGRAMMA DI CLASSE 5AI Istituto di Istruzione Superiore Euganeo Istituto tecnico del settore tecnologico Istituto professionale del settore servizi socio-sanitari Istituto professionale del settore industria e artigianato PROGRAMMA

Dettagli

SISTEMI INFORMATIVI AVANZATI -2010/2011 1. Introduzione

SISTEMI INFORMATIVI AVANZATI -2010/2011 1. Introduzione SISTEMI INFORMATIVI AVANZATI -2010/2011 1 Introduzione In queste dispense, dopo aver riportato una sintesi del concetto di Dipendenza Funzionale e di Normalizzazione estratti dal libro Progetto di Basi

Dettagli

Informatica. Sintassi. Interrogazioni in SQL. Significato dell interrogazione. Tabella Impiegato. Basi di dati parte 4 SQL

Informatica. Sintassi. Interrogazioni in SQL. Significato dell interrogazione. Tabella Impiegato. Basi di dati parte 4 SQL Informatica Basi di dati parte 4 SQL Lezione 13 Laurea magistrale in Scienze della mente Laurea magistrale in Psicologia dello sviluppo e dell'educazione Anno accademico: 2012 2013 1 Interrogazioni in

Dettagli

Basi di Dati prof. Letizia Tanca

Basi di Dati prof. Letizia Tanca Basi di Dati prof. Letizia Tanca (lucidi tratti dal libro Atzeni-Ceri-Paraboschi-Torlone) AA 2003-04 Linguaggi di interrogazione commerciali per il Modello Relazionale dei Dati: SQL - il DDL Domini I domini

Dettagli

I comandi del linguaggio DDL (Data Definition Language): CREATE E ALTER

I comandi del linguaggio DDL (Data Definition Language): CREATE E ALTER Caratteristiche generali del linguaggio SQL Il linguaggio SQL è il linguaggio usato per la gestione dei database relazionali, cioè dei database creati con un DBMS di tipo relazionale. Esso nacque nella

Dettagli

********************* MODIFICA STRUTTURA DI UNA TABELLA (inserimento di un nuovo campo) ALTER TABLE Personale ADD Nascita date;

********************* MODIFICA STRUTTURA DI UNA TABELLA (inserimento di un nuovo campo) ALTER TABLE Personale ADD Nascita date; CREAZIONE STRUTTURA DI UNA TABELLA by Marinsalta Fausto CREATE TABLE Personale Matricola char(5), Cognome char(30), Nome char(20), Codfis char(16) not null, Assunzione date, Filiale smallint, Funzione

Dettagli

a.a. 2012/13 12 Novembre 2012 Preparazione al Test in itinere, Compito A 1. Modellare tramite uno schema entità- relazione la seguente base di dati:

a.a. 2012/13 12 Novembre 2012 Preparazione al Test in itinere, Compito A 1. Modellare tramite uno schema entità- relazione la seguente base di dati: Gestione dei dati e della conoscenza, a.a. 2012/13 12 Novembre 2012 Preparazione al Test in itinere, Compito A 1. Modellare tramite uno schema entità- relazione la seguente base di dati: Si vuole modellare

Dettagli

Il Modello Relazionale

Il Modello Relazionale Il Modello Relazionale Il modello relazionale 1 Il modello relazionale Proposto da E. F. Codd nel 1970 per favorire l indipendenza dei dati e reso disponibile come modello logico in DBMS reali nel 1981

Dettagli

Interrogazioni nidificate, commenti

Interrogazioni nidificate, commenti Interrogazioni nidificate, commenti La forma nidificata è meno dichiarativa, ma talvolta più leggibile (richiede meno variabili) La forma piana e quella nidificata possono essere combinate Le sottointerrogazioni

Dettagli

Utilizzando Microsoft Access. Si crea la tabella Anagrafica degli alunni,le Materie e i voti si mettono alcuni campi

Utilizzando Microsoft Access. Si crea la tabella Anagrafica degli alunni,le Materie e i voti si mettono alcuni campi Vogliamo creare una struttura per permettere di memorizzari i voti della classe in tutte le materie Per fare questo untilizziamo tre tabelle Alunni,materie,voti Alunni Materie Voti Creo un record per ogni

Dettagli

I database relazionali sono il tipo di database attualmente piu diffuso. I motivi di questo successo sono fondamentalmente due:

I database relazionali sono il tipo di database attualmente piu diffuso. I motivi di questo successo sono fondamentalmente due: Il modello relazionale I database relazionali sono il tipo di database attualmente piu diffuso. I motivi di questo successo sono fondamentalmente due: 1. forniscono sistemi semplici ed efficienti per rappresentare

Dettagli

SQL prima parte D O C E N T E P R O F. A L B E R T O B E L U S S I. Anno accademico 2011/12

SQL prima parte D O C E N T E P R O F. A L B E R T O B E L U S S I. Anno accademico 2011/12 SQL prima parte D O C E N T E P R O F. A L B E R T O B E L U S S I Anno accademico 2011/12 DEFINIZIONE Il concetto di vista 2 È una relazione derivata. Si specifica l espressione che genera il suo contenuto.

Dettagli

Basi di Dati prof. Letizia Tanca lucidi ispirati al libro Atzeni-Ceri-Paraboschi-Torlone. SQL: il DDL

Basi di Dati prof. Letizia Tanca lucidi ispirati al libro Atzeni-Ceri-Paraboschi-Torlone. SQL: il DDL Basi di Dati prof. Letizia Tanca lucidi ispirati al libro Atzeni-Ceri-Paraboschi-Torlone SQL: il DDL Parti del linguaggio SQL Definizione di basi di dati (Data Definition Language DDL) Linguaggio per modificare

Dettagli

Interrogazioni complesse. SQL avanzato 1

Interrogazioni complesse. SQL avanzato 1 Interrogazioni complesse SQL avanzato Classificazione delle interrogazioni complesse Query con ordinamento Query con aggregazione Query con raggruppamento Query binarie Query annidate SQL avanzato 2 Esempio

Dettagli

INFORMATICA. Applicazioni WEB a tre livelli con approfondimento della loro manutenzione e memorizzazione dati e del DATABASE.

INFORMATICA. Applicazioni WEB a tre livelli con approfondimento della loro manutenzione e memorizzazione dati e del DATABASE. INFORMATICA Applicazioni WEB a tre livelli con approfondimento della loro manutenzione e memorizzazione dati e del DATABASE. APPLICAZIONI WEB L architettura di riferimento è quella ampiamente diffusa ed

Dettagli

Il linguaggio SQL: le basi. Versione elettronica: SQLa-basi.pdf

Il linguaggio SQL: le basi. Versione elettronica: SQLa-basi.pdf Il linguaggio SQL: le basi Versione elettronica: SQLa-basi.pdf SQL: caratteristiche generali SQL (Structured Query Language) è il linguaggio standard de facto per DBMS relazionali, che riunisce in sé funzionalità

Dettagli

Linguaggio SQL. Prof. Francesco Accarino IIS Altiero Spinelli Sesto San Giovanni

Linguaggio SQL. Prof. Francesco Accarino IIS Altiero Spinelli Sesto San Giovanni Linguaggio SQL Prof. Francesco Accarino IIS Altiero Spinelli Sesto San Giovanni SQL: caratteristiche generali SQL (Structured Query Language) è il linguaggio standard de facto per DBMS relazionali, che

Dettagli

OSSIF WEB. Manuale query builder

OSSIF WEB. Manuale query builder OSSIF WEB Manuale query builder - Maggio 2010 1) Sommario 1) SOMMARIO... 2 INTRODUZIONE... 3 Scopo del documento... 3 Struttura del documento... 3 Descrizione dell interfaccia grafica... 3 SELEZIONE DI

Dettagli

SQL PER LA DEFINIZIONE DI BASI DI DATI

SQL PER LA DEFINIZIONE DI BASI DI DATI SQL PER LA DEFINIZIONE DI BASI DI DATI SQL non è solo un linguaggio di interrogazione (Query Language), ma Un linguaggio per la definizione di basi di dati (Data-definition language (DDL)) CREATE SCHEMA

Dettagli

MODELLO RELAZIONALE. cesarini-bdsi mod relazionale 1 MODELLO RELAZIONALE

MODELLO RELAZIONALE. cesarini-bdsi mod relazionale 1 MODELLO RELAZIONALE MODELLO RELAZIONALE Definizione di relazione Schema e istanza Chiave Valori nulli Predicati e vincoli di integrità Vincolo di integrità referenziale cesarini-bdsi mod relazionale 1 MODELLO RELAZIONALE

Dettagli

(anno accademico 2008-09)

(anno accademico 2008-09) Calcolo relazionale Prof Alberto Belussi Prof. Alberto Belussi (anno accademico 2008-09) Calcolo relazionale E un linguaggio di interrogazione o e dichiarativo: at specifica le proprietà del risultato

Dettagli

Corso di Informatica (Basi di Dati)

Corso di Informatica (Basi di Dati) Corso di Informatica (Basi di Dati) Lezione 6 (15 gennaio 2009) Linguaggio SQL: Data Definition Language (DDL) Da: Atzeni, Ceri, Paraboschi, Torlone - Basi di Dati Lucidi del Corso di Basi di Dati 1, Prof.

Dettagli

Data Management Software. Il linguaggio SQL. Raggruppamenti. Paolo Avallone Sr Consulting IT Specialist DB2, Data Management Marzo 2004

Data Management Software. Il linguaggio SQL. Raggruppamenti. Paolo Avallone Sr Consulting IT Specialist DB2, Data Management Marzo 2004 DB2 Data Management Software Il linguaggio SQL Raggruppamenti Paolo Avallone Sr Consulting IT Specialist DB2, Data Management Marzo 2004 LEGGERE LE SEGUENTI ATTENZIONI Le informazioni contenute in questa

Dettagli

Basi di Dati Corso di Laura in Informatica Umanistica

Basi di Dati Corso di Laura in Informatica Umanistica Basi di Dati Corso di Laura in Informatica Umanistica Appello del 10/09/2010 Parte 1: Algebra Relazionale e linguaggio SQL Docente: Giuseppe Amato Sia dato il seguente schema di base di dati per la gestione

Dettagli

Informatica per le discipline umanistiche 2 lezione 10

Informatica per le discipline umanistiche 2 lezione 10 Informatica per le discipline umanistiche 2 lezione 10 Parte III: il computer come strumento per l interazione e la comunicazione Si è parlato di identità Parte III: il computer come strumento per l interazione

Dettagli

Corso di Informatica Generale 1 IN1. Linguaggio SQL

Corso di Informatica Generale 1 IN1. Linguaggio SQL Università Roma Tre Facoltà di Scienze M.F.N. di Laurea in Matematica di Informatica Generale 1 Linguaggio SQL Marco (liverani@mat.uniroma3.it) Sommario Prima parte: le basi dati relazionali Basi di dati:

Dettagli

ECDL - Database. European Computer Driving Licence - Modulo 5 - Database LEZIONE 2

ECDL - Database. European Computer Driving Licence - Modulo 5 - Database LEZIONE 2 ECDL - Database European Computer Driving Licence - Modulo 5 - Database LEZIONE 2 Ripasso Introduzione - Ripasso Cosa si intende per dbms? e cosa per database? Quali sono gli elementi che lo compongono?

Dettagli

Corso di Basi di Dati A.A. 2013/2014

Corso di Basi di Dati A.A. 2013/2014 Corso di Laurea in Ingegneria Gestionale Sapienza Università di Roma Corso di Basi di Dati A.A. 2013/2014 Tiziana Catarci, Andrea Marrella Ultimo aggiornamento : 29/03/2014 SQL : Structured Query Language

Dettagli

Uso delle variabili di alias. SQL slide aggiuntive. Interrogazione 25. Interrogazione 26

Uso delle variabili di alias. SQL slide aggiuntive. Interrogazione 25. Interrogazione 26 Uso delle variabili di alias SQL slide aggiuntive Laurea magistrale in Scienze della mente Laurea magistrale in Psicologia dello sviluppo e dell'educazione educazione Non solo per disambiguare la notazione

Dettagli

Basi di Dati. Laboratorio Ing. G. Laboccetta Dott.ssa. V. Policicchio. Corso di Laurea in Informatica. a.a. 2010-2011

Basi di Dati. Laboratorio Ing. G. Laboccetta Dott.ssa. V. Policicchio. Corso di Laurea in Informatica. a.a. 2010-2011 Corso di Laurea in Informatica Basi di Dati a.a. 2010-2011 Laboratorio Ing. G. Laboccetta Dott.ssa. V. Policicchio PROGETTAZIONE FISICA SQL-DDL OBIETTIVO: Rappresentare i dati della realtà di interesse

Dettagli

Esercitazione di riepilogo sulle Query MySQL Giugno 2011 Classe VB Informatica

Esercitazione di riepilogo sulle Query MySQL Giugno 2011 Classe VB Informatica Istituto di Istruzione Superiore Alessandrini - Marino 1 Esercitazione di riepilogo sulle Query MySQL Giugno 2011 Classe VB Informatica Descrizione Un azienda commerciale che vende prodotti IT (computers,

Dettagli

Il linguaggio SQL. Evoluzione del linguaggio. I linguaggi dentro SQL. I dialeu SQL. U@lizzo di SQL SQL. A. Ferrari 1

Il linguaggio SQL. Evoluzione del linguaggio. I linguaggi dentro SQL. I dialeu SQL. U@lizzo di SQL SQL. A. Ferrari 1 Il linguaggio SQL Structured Query Language SQL è un linguaggio di interrogazione per database proge

Dettagli

2104 volume III Programmazione

2104 volume III Programmazione 2103 SQLite Capitolo 77 77.1 Utilizzo generale................................. 2104 77.1.1 Utilizzo di sqlite3».......................... 2104 77.1.2 Copie di sicurezza............................ 2106

Dettagli

CAPITOLO 4 ESERCIZI SU SQL

CAPITOLO 4 ESERCIZI SU SQL CAPITOLO 4 ESERCIZI SU SQL (le soluzioni sono riportate da pag. 5 in poi (Nota: gli esercizi non sono sempre in ordine di difficoltà Esercizio 1 Si prendano tutti gli schemi relazionali considerati negli

Dettagli

SQL: Structured Query Language. T. Catarci, M. Scannapieco, Corso di Basi di Dati, A.A. 2008/2009, Sapienza Università di Roma

SQL: Structured Query Language. T. Catarci, M. Scannapieco, Corso di Basi di Dati, A.A. 2008/2009, Sapienza Università di Roma SQL: Structured Query Language 1 SQL:Componenti Principali Data Manipulation Language (DML): interrogazioni, inserimenti, cancellazioni, modifiche Data Definition Language (DDL): creazione, cancellazione

Dettagli

Basi di dati. Il Modello Relazionale dei Dati. K. Donno - Il Modello Relazionale dei Dati

Basi di dati. Il Modello Relazionale dei Dati. K. Donno - Il Modello Relazionale dei Dati Basi di dati Il Modello Relazionale dei Dati Proposto da E. Codd nel 1970 per favorire l indipendenza dei dati Disponibile come modello logico in DBMS reali nel 1981 (non è facile realizzare l indipendenza

Dettagli