Basi di Dati: Corso di laboratorio

Dimensione: px
Iniziare la visualizzazioe della pagina:

Download "Basi di Dati: Corso di laboratorio"

Transcript

1 Basi di Dati: Corso di laboratorio Lezione 1 Raffaella Gentilini 1 / 67

2 Sommario 1 Introduzine al Linguaggio SQL Concetti Preliminari / 67

3 Concetti Preliminari Il linguaggio SQL SQL Acronimo per Structured Query Language Il linguaggio SQL ha varie funzionalita : 3 / 67

4 Concetti Preliminari Il linguaggio SQL SQL Acronimo per Structured Query Language Il linguaggio SQL ha varie funzionalita : 1) Data Definition Language (DDL): Permette di definire, modificare e cancellare strutture dati e vincoli di integrita. Istruzioni del DDL: CREATE, ALTER, DROP, RENAME, TRUNCATE... 4 / 67

5 Concetti Preliminari Il linguaggio SQL SQL Acronimo per Structured Query Language Il linguaggio SQL ha varie funzionalita : 2) Data Manipulation Language (DML) Consente la manipolazione dei dati. In particolare, il DML consente di estrarre, modificare e cancellare i dati contenuti nella base di dati. Istruzioni del DML: SELECT, INSERT, UPDATE, DELETE... 5 / 67

6 Concetti Preliminari Il linguaggio SQL SQL Acronimo per Structured Query Language Il linguaggio SQL ha varie funzionalita : 3) Data Control Language (DCL) Permette di gestire i privilegi degli utenti della base di dati. Istruzioni del DCL: GRANT, REVOKE 6 / 67

7 Concetti Preliminari Il linguaggio SQL SQL Acronimo per Structured Query Language Il linguaggio SQL ha varie funzionalita : 4) Transaction Control Language (TCL) Permette di gestire le transazioni ed in particolare la validazione e l annulamento delle modifiche della base di dati definite mediante il DDL ed il DML. Istruzioni del TCL: COMMIT, SAVEPOINT, ROLLBACK, SET TRANSACTION 7 / 67

8 Concetti Preliminari Il linguaggio SQL SQL Acronimo per Structured Query Language Il linguaggio SQL ha varie funzionalita : 5) Embedded SQL Permette di integrare i comandi SQL in un linguaggio ospite (C, C++, Java... ) 8 / 67

9 Concetti Preliminari Il linguaggio SQL nel Tempo SQL:Un po di storia 1974 Prima proposta SEQUEL (IBM Research) 1981 Prime implementazioni in SQL/DS (IBM) e Oracle Dal 1983 e uno standard di fatto: standard 1986, standard 1992, poi 1999, e infine recepito solo in parte 9 / 67

10 Concetti Preliminari SQL-92 SQL-92 E un linguaggio ricco e complesso ancora nessun sistema mette a disposizione tutte le funzionalita del linguaggio 3 livelli di aderenza allo standard: Entry SQL: Abbastanza simile a SQL-89 Intermediate SQL Supportato dai DBMS tradizionali/ caratteristiche piu importanti per le esigenze del mercato Full SQL: Funzioni avanzate, in via di inclusione nei sistemi i sistemi offrono funzionalita non standard incompatibilia tra sistemi/ con i nuovi standard (SQL-99) Nuovi standard conservano caratteristiche di base di SQL-92 SQL-99: Aggiunge alcune funzionalita orientate agli oggetti SQL-03: Aggiunge il supporto per dati XML 10 / 67

11 Concetti Preliminari Utilizzo di un DBMS basato su SQL Un DBMS basato su SQL consente di gestire basi di dati relazionali. Dal punto di vista sistemistico e un server. Quando ci si connette ad un DBMS basato su SQL si deve indicare, implicitamente o esplicitamente, su quale base di dati si vuole operare Se si vuole utilizzare una base di dati non ancora esistente, si utilizza un meccanismo messo a disposizione dal server per la sua creazione Coerentemente con la filosofia del modello relazionale, una base di dati in SQL e caratterizzata dallo schema (livello intensionale) e da una istanza (quella corrente livello estensionale) Inoltre, una base di dati SQL e caratterizzata da un insieme di meta-dati (il catalogo) 11 / 67

12 Astrazione dei dati in SQL 12 / 67

13 Definizione di uno schema Concetto di Schema Uno schema permette di dividere logicamente una base di dati in parti separate che possono comunicare tra loro. E identificato da un nome di schema 13 / 67

14 Definizione di uno schema Concetto di Schema Uno schema permette di dividere logicamente una base di dati in parti separate che possono comunicare tra loro. E identificato da un nome di schema Example La seguente istruzione del DDL di SQL crea uno schema chiamato Ditta: CREATE SCHEMA Ditta; 14 / 67

15 Definizione di uno schema Sintassi dell istruzione CREATE SCHEMA CREATE SCHEMA <nome database> [AUTHORIZATION<nome prop>] A seguito del nome, uno schema puo contenere: 15 / 67

16 Definizione di uno schema Sintassi dell istruzione CREATE SCHEMA CREATE SCHEMA <nome database> [AUTHORIZATION<nome prop>] A seguito del nome, uno schema puo contenere: un identificatore di autorizzazione per indicarne il proprietario proprietario (se vuoto: l utente) 16 / 67

17 Definizione di uno schema Sintassi dell istruzione CREATE SCHEMA CREATE SCHEMA <nome database> [AUTHORIZATION<nome prop>] A seguito del nome, uno schema puo contenere: un identificatore di autorizzazione per indicarne il proprietario proprietario (se vuoto: l utente) definizioni di tabelle, domini, viste, privilegi, vincoli e funzioni. 17 / 67

18 Metalinguaggio di Sintassi [ ] Le parentesi quadre indicano che il contenuto e opzionale < > Indicano che il contenuto e di libero arbitrio (e.g. scelta del nome dello schema) { } Indicano una scelta (e.g. {item1 item2} indica la scelta tra item1 ed item2)... I punti di sospensione indicano la possiblita di una ripetizione 18 / 67

19 Oggetti di uno schema Dopo aver creato uno schema e possibile aggiungere oggetti al suo interno qualificandone il nome mediante il nome dello schema seguito da un punto Example CREATE DOMAIN Ditta.dom stipendio AS NUMERIC(8, 2) CHECK VALUE 900; CREATE DOMAIN Ditta.dom cod impiegato AS VARCHAR(4); CREATE TABLE Ditta.Impiegato ( cod Ditta.dom cod impiegato PRIMARY KEY, nome varchar(40) NOT NULL, stipendio Ditta.dom stipendio ); 19 / 67

20 Oggetti di uno schema Example Di solito lo schema SQL in cui vengono dichirati gli oggetti (tabelle, domini... ) e specificato implicitamente dall ambiente in cui vengono eseguite le rispettive istruzioni di CREATE In tal caso non e necessario associare esplicitamente il nome dello schema ai nomi degli oggetti separandoli con un punto CREATE TABLE Impiegato ( cod dom cod impiegato PRIMARY KEY, nome varchar(40) NOT NULL, stipendio dom stipendio ); 20 / 67

21 Schemi predefiniti in PostgreSQL In PostgreSQL esiste uno schema predefinito public. Quando un elemento della base di dati viene creato o riferito senza la qualificazione di uno schema, il sistema assume che la qualificazione sia public. Example Ad esempio, l istruzione: CREATE TABLE R (a CHAR PRIMARY KEY, b CHAR); equivale a: CREATE TABLE public.r (a CHAR PRIMARY KEY, b CHAR); 21 / 67

22 CREATE TABLE L istruzione del DDL di SQL CREATE TABLE: definisce uno schema di relazione ( tabella) crea un istanza vuota dello schema specifica attributi, domini e vincoli. 22 / 67

23 CREATE TABLE: Sintassi Example CREATE TABLE utente( VARCHAR(40) NOT NULL, nome VARCHAR(30) NOT NULL, cognome VARCHAR(30) NOT NULL, anno nascita INTEGER, PRIMARY KEY ( )); 23 / 67

24 CREATE TABLE: Sintassi Example CREATE TABLE utente( VARCHAR(40) NOT NULL, nome VARCHAR(30) NOT NULL, cognome VARCHAR(30) NOT NULL, anno nascita INTEGER, PRIMARY KEY ( )); Sintassi dell istruzione CREATE TABLE CREATE TABLE <nome tab> ( <nome col><dominio> [DEFAULT<val>] [<vincolo col> [... ]] [, {<nome col><dominio> [DEFAULT<val>] [<vincolo col> [... ]] <vincolo tab>}[,... ]]) 24 / 67

25 CREATE TABLE: Sintassi Example CREATE TABLE utente( VARCHAR(40) NOT NULL, nome VARCHAR(30) NOT NULL, cognome VARCHAR(30) NOT NULL, anno nascita INTEGER, PRIMARY KEY ( )); Sintassi dell istruzione CREATE TABLE CREATE TABLE <nome tab> ( <nome col><dominio> [DEFAULT<val>] [<vincolo col> [... ]] [, {<nome col><dominio> [DEFAULT<val>] [<vincolo col> [... ]] <vincolo tab>}[,... ]]) 25 / 67

26 CREATE TABLE: Sintassi Example CREATE TABLE utente( VARCHAR(40) NOT NULL, nome VARCHAR(30) NOT NULL, cognome VARCHAR(30) NOT NULL, anno nascita INTEGER, PRIMARY KEY ( )); Sintassi dell istruzione CREATE TABLE CREATE TABLE <nome tab> ( <nome col><dominio> [DEFAULT<val>] [<vincolo col> [... ]] [, {<nome col><dominio> [DEFAULT<val>] [<vincolo col> [... ]] <vincolo tab>}[,... ]]) 26 / 67

27 CREATE TABLE: Sintassi Example CREATE TABLE utente( VARCHAR(40) NOT NULL, nome VARCHAR(30) NOT NULL, cognome VARCHAR(30) NOT NULL, anno nascita INTEGER, PRIMARY KEY ( )); Sintassi dell istruzione CREATE TABLE CREATE TABLE <nome tab> ( <nome col><dominio> [DEFAULT<val>] [<vincolo col> [... ]] [, {<nome col><dominio> [DEFAULT<val>] [<vincolo col> [... ]] <vincolo tab>}[,... ]]) 27 / 67

28 CREATE TABLE: Sintassi Example CREATE TABLE utente( VARCHAR(40) NOT NULL, nome VARCHAR(30) NOT NULL, cognome VARCHAR(30) NOT NULL, anno nascita INTEGER, PRIMARY KEY ( )); Sintassi dell istruzione CREATE TABLE CREATE TABLE <nome tab> ( <nome col><dominio> [DEFAULT<val>] [<vincolo col> [... ]] [, {<nome col><dominio> [DEFAULT<val>] [<vincolo col> [... ]] <vincolo tab>}[,... ]]) 28 / 67

29 CREATE TABLE: Sintassi Example CREATE TABLE utente( VARCHAR(40) NOT NULL, nome VARCHAR(30) NOT NULL, cognome VARCHAR(30) NOT NULL, anno nascita INTEGER, PRIMARY KEY ( )); Sintassi dell istruzione CREATE TABLE CREATE TABLE <nome tab> ( <nome col><dominio> [DEFAULT<val>] [<vincolo col> [... ]] [, {<nome col><dominio> [DEFAULT<val>] [<vincolo col> [... ]] <vincolo tab>}[,... ]]) 29 / 67

30 CREATE TABLE <nome tab> ( <nome col><dominio> [DEFAULT<val>] [<vincolo col> [... ]] [, {<nome col><dominio> [DEFAULT<val>] [<vincolo col> [... ]] <vincolo tab>}[,... ]]) 1 Elementari (predefiniti) Carattere: singoli caratteri o stringhe anche di lunghezza variabile Bit: flag booleani o stringhe Numerici esatti ed approssimati data, ora, intervalli di tempo 2 definiti dall utente 30 / 67

31 o Carattere o char(n) char varchar(n) Descrizione Stringhe di n caratteri (lunghezza fissa). A stringhe piu corte sono aggiunti spazi in coda. sinonimo di char(1) Stringhe di al piu n caratteri 31 / 67

32 Numerici: Tipi Numerici Esatti (I) Permette di rappresentare valori interi o decimali mediante una rappresentazione in virgola fissa. o Descrizione smallint Intero. 2 byte, range [ 2 15, ] integer Intero. 4 byte, range [ 2 31, ] 32 / 67

33 Numerici: Tipi Numerici Esatti (II) Permette di rappresentare valori interi o decimali mediante una rappresentazione in virgola fissa. o numeric(prec,scala) numeric decimal(prec,scala) Descrizione per calcoli esatti fino a 1000 cifre significative. Scala e il numero di cifre dopo la virgola. Prec e il numero di cifre significative Esempio: ha precisione 6 e scala 4. Gli interi hanno scala 0. Memorizza numeri decimali fino alla precisione massima consentita dall implementazione, e assume scala 0. come numeric(prec,scala) ma assume che prec sia limite inferiore alla precisione. 33 / 67

34 Numerici: Tipi Numerici Approssimati Permette di rappresentare valori numerici approssimati mediante una rappresentazione in virgola mobile. o real double precision float(prec) Descrizione Numeri in virgola mobile. Tipicamente nel range [10 37, ], con almeno 6 cifre corrette Numeri in virgola mobile. Tipicamente nel range [10 307, ], con almeno 15 cifre corrette prec specifica la precisione minima accettabile come numero di cifre binarie. 34 / 67

35 Temporali o timestamp date time interval Descrizione Data e ora. Esempio: 10-may :30:10 Data. Esempio: (formato raccomandabile anno-mese-giorno ) Ora. Esempio: 5.50 pm Intervalli di tempo. Esempio: 1 day 12 hours 50 min 10 sec ago 35 / 67

36 Booleani o boolean Descrizione Tipo booleano. Esempi di valori booleani: TRUE, FALSE/ t, f / true, false, y, n / yes, no, 1, 0 36 / 67

37 definiti dall utente definiti dall utente L utente puo definire i propri domini con l istruzione: Example CREATE DOMAIN CREATE DOMAIN provincia AS CHAR(2) NOT NULL; 37 / 67

38 definiti dall utente Example CREATE DOMAIN voto AS INTEGER CHECK (VALUE BETWEEN 18 AND 30) oppure CREATE DOMAIN voto AS INTEGER CHECK (VALUE > 17 AND VALUE 30) Example CREATE DOMAIN nat pari AS INTEGER CONSTRAINT positivo CHECK (VALUE 0) CONSTRAINT positivo CHECK (VALUE %20) 38 / 67

39 Vincoli Intrarelazionali Proprieta che devono essere soddisfatte da ogni istanza di relazione della base di dati. Si riferiscono a singole relazioni della base di dati. in SQL: NOT NULL: attributo non nullo UNIQUE: definisce (super-) chiavi PRIMARY KEY: definisce la chiave primaria (una sola, implica NOT NULL) CHECK(condizione): vincolo generico 39 / 67

40 NOT NULL NOT NULL Il valore nullo non e ammesso come valore dell attributo. Example Il valore dell attributo deve essere specificato in fase di inserimento. CREATE TABLE Ditta.Impiegato ( cod Ditta.dom cod impiegato PRIMARY KEY, nome VARCHAR(40) NOT NULL, stipendio Ditta.dom stipendio ); 40 / 67

41 UNIQUE UNIQUE Impone che i valori di un attributo (oppure di un insieme di attributi) siano una superchiave, quindi tuple differenti della stessa tabella non possono avere gli stessi valori. Si puo definire su: un solo attributo Matricola CHAR(6) UNIQUE un insieme di attributi Nome VARCHAR(20) Cognome VARCHAR(20) UNIQUE(Nome,Cognome); 41 / 67

42 UNIQUE UNIQUE su insieme di attributi Nome VARCHAR(20) NOT NULL, Cognome VARCHAR(20) NOT NULL, UNIQUE(Nome,Cognome) Impone che non ci siano due righe che abbiano uguale sia il nome che il cognome UNIQUE su singoli attributi Nome VARCHAR(20) NOT NULL UNIQUE, Cognome VARCHAR(20) NOT NULL UNIQUE Impone che non ci siano due righe che abbiano lo stesso nome o lo stesso cognome 42 / 67

43 PRIMARY KEY Specifica la chiave primaria della relazione Si usa una sola volta per tabella Implica una definizione di not null Due forme 1 In definizione di un attibuto, se forma da solo chiave primaria Matricola CHAR(20)PRIMARY KEY 2 Come elemento separato (quando la chiave primaria e composta da piu attributi) Nome VARCHAR(20), Cognome VARCHAR(20), PRIMARY KEY(Nome, Cognome) 43 / 67

44 CHECK Introduzine al Linguaggio SQL Example CREATE TABLE Impiegato ( Matricola CHAR(6) PRIMARY KEY, Nome VARCHAR(20) NOT NULL, Cognome VARCHAR(20) NOT NULL, Stipendio FLOAT DEFAULT 1000, UNIQUE(Cognome,Nome), CHECK Stipendio 1000); 44 / 67

45 Vincoli intrarelazionali di colonna: Sintassi Sintassi di specifica dei vincoli intrarelazionali definiti su singoli attributi: [CONSTRAINT <nome vincolo>] {NOT NULL UNIQUE PRIMARY KEY CHECK(<condizione>)} 45 / 67

46 Vincoli intrarelazionali di tabella: Sintassi Sintassi di specifica dei vincoli intrarelazionali definiti su insiemi di attributi: [CONSTRAINT <nome vincolo>] { PRIMARY KEY( <nome colonna> [,... ] ) UNIQUE( <nome colonna> [,... ] ) CHECK( <condizione>)} 46 / 67

47 Vincoli di Integrita Interelazionali Vincoli di Integrita Interelazionali Vincoli che coinvolgono piu relazioni I piu significativi sono i vincoli di integrita referenziale o vincoli di riferimento In SQL i vincoli di integrita referenziale sono definiti mediante il concetto di chiave esterna o chiave esportata. 47 / 67

48 Chiave Esterna Chiave Esterna Crea un legame tra: i valori (di uno o piu ) attributi della tabella corrente (tabella interna) i valori (di uno o piu ) attributi di un altra tabella (tabella esterna) Impone che per ogni riga della tabella interna il valore dell attributo (l insieme di valori di attributi) sia presente tra i valori (l insieme di valori) di un attributo della tabella esterna dell attributo L attributo della tabella esterna a cui si fa riferimento deve essere soggetto a vincolo UNIQUE o PRIMARY KEY (vincolo di tabella se sono coinvolti piu di un attributo) 48 / 67

49 Chiave esterna REFERENCES e FOREIGN KEY SQL fornisce due costrutti di base per la definizione di chiavi esterne: 1 Costrutto REFERENCES, per la definizione di chiavi esterne su un attributo (mediante vincolo di colonna) 2 Costrutto FOREIGN KEY per la definizione di chaivi esterne su piu attributi (mediante vincolo di tabella) 49 / 67

50 Costrutto REFERENCES REFERENCES Si usa il solo costrutto REFERENCES quando il vincolo e definito su un singolo attributo Con REFERENCES (nella tabella interna) si specificano: la tabella esterna, e l attributo della tabella esterna con il quale l attributo della tabella interna deve essere legato 50 / 67

51 Uso del Costrutto REFERENCES Example CREATE TABLE dipartimento( nome dip VARCHAR(15) PRIMARY KEY, sede VARCHAR(20) NOT NULL); CREATE TABLE impiegato( matricola CHAR(6) PRIMARY KEY, nome VARCHAR(20) NOT NULL, cognome VARCHAR(20) NOT NULL, nome dpt VARCHAR(15) REFERENCES dipartimento(nome dip)); 51 / 67

52 Costrutto FOREIGN KEY FOREIGN KEY Si usa il costrutto FOREIGN KEY+REFERENCES quando il vincolo e definito su un insieme di attributi Con FOREIGN KEY nella tabella interna si elencano gli attributo della tabella interna coinvolti nel legame Con REFERENCES nella tabella tabella interna si specificano la tabella esterna e gli attributi della tabella esterna con i quali gli attributi della tabella interna devono essere legati 52 / 67

53 Uso del Costrutto FOREIGN KEY Example CREATE TABLE anagrafica( codice fiscale CHAR(11) PRIMARY KEY, nome VARCHAR(20) NOT NULL, cognome VARCHAR(20) NOT NULL, UNIQUE(nome, cognome)); CREATE TABLE impiegato( matricola CHAR(6) PRIMARY KEY, nome VARCHAR(20) NOT NULL, cognome VARCHAR(20) NOT NULL, nome dpt VARCHAR(15) REFERENCES dipartimento(nome dip), FOREIGN KEY(nome, cognome) REFERENCES anagrafica(nome, cognome)); 53 / 67

54 PostgreSQL PostgreSQL Sistema di gestione di basi di dati relazionali ad oggetti sviluppato in varie fasi sin dal 1977 E largamente considerato il sistema di gestione di basi di dati open source piu avanzato L interazione tra un utente e la base di dati segue il modello client-server 54 / 67

55 Lavorare in psql Client testuale psql psql e un client a riga di comando, distribuito insieme a PostgreSQL, psql, pur essend semplice, e molto potente e permette l interazione diretta con il server postgresql 55 / 67

56 Accesso all archivio Accesso all archivio psql -U <nome utente> -h <hostname> <database> Subito dopo l avvio di psql appare un breve sommario di alcuni comandi slash: \h per l aiuto su SQL \? per l aiuto sui comandi psql \q per uscire da psql una volta terminato 56 / 67

57 Comandi di slash \a Attiva e disattiva la modalita di allineamento \c[onnect] [nomedb - [utente]] Si connette ad un nuovo database \C <titolo> Titolo della tabella \d <table> Descrive la tabella (o la vista) \d{t i s v} Elenca tabelle/indici/sequenze/viste \d{p S l} Elenca permessi/tabelle di sistema/large objects \da Elenca gli aggregati 57 / 67

58 Comandi di Slash \dd [oggetto] Elenca i commenti per tabella, tipo, funzione o operatore \df Elenca le funzioni \do Elenca gli operatori \dt Elenca i tipi di dati \e [file]: Permette la modifica del buffer della query attuale o di [file] con un editor esterno \echo <testo>: scrive il testo sullo stdout \f <sep>: Cambia il separatore dei campi 58 / 67

59 Comandi di Slash \g [file] Invia la query al backend (e i risultati in [file]) \h [cmd] aiuto sulla sintassi dei comandi SQL \H Attiva o disattiva la modalita HTML (attualmente disinserita) \i <file> Legge ed esegue la query da file \l: Elenca tutti i databases \o [file]: Invia tutti i risultati della query nel [file] \p: mostra il contenuto del buffer della query attuale \q: Esce da psql 59 / 67

60 Comandi di Slash \r Cancella il buffer della query \s [file] Stampa lo storico dei comandi e lo salva in [file] \set <var> <valore> Imposta una variabile interna \t Visualizza solo le righe \T <tags> Imposta gli attributi dei tag HTML per le tabelle \unset <var> Elimina una variabile interna \w <file> scrive il buffer della query attuale su file \x Attiva e disattiva l output esteso \z Elenca i permessi di accesso alle tabelle \d![cmd] Esce sulla shell o esegue un comando 60 / 67

61 in PostgreSQL Caratteri Oltre ai domini predefiniti per le stringhe previsti dallo standard SQL, PostgreSQL accetta: character varying, o varchar (senza specificare una dimensione massima) per stringhe di lunghezza arbitraria. text per stringhe di arbitraria lunghezza 61 / 67

62 in PostgreSQL Numeri Interi Oltre ai domini predefiniti per i valori numerici interi previsti dallo standard SQL, PostgreSQL: definisce un tipo bigint che usa 8 byte. 62 / 67

63 in PostgreSQL Numeri decimali con precisione arbitraria Estensioni allo standard SQL PostgreSQL: numeric memorizza numeri decimali fino alla precisione massima consentita, senza forzare una scala numeric e decimal sono equivalenti in PostgreSQL 63 / 67

64 in PostgreSQL Numeri in virgola mobile Estensioni allo standard SQL in PostgreSQL: float(1) -- foat(24) equivale a real float(25) -- foat(53) equivale a double precision altri valori danno errore 64 / 67

65 Riepilogo e Sommario A riepilogo dei concetti introdotti, consideriamo la definizione in PostgreSQL della BD per la memorizzazione di un gruppo di persone e dei corrispondenti rapporti genitore/figlio, costituita dalle tabelle: persone(id, nome, reddito,eta,sesso) soggetta ai vincoli: id: (stringa di due caratteri) e chiave primaria nome: (stringa di 20 caratteri) non puo essere NULL reddito: (intero), in migliaia di euro, 0 per default eta: intero < 200, sesso: M oppure F genitori(figlio,genitore,) soggetta ai vincoli: figlio (stringa di 2 caratteri) chiave esterna su persone genitore (stringa di 2 caratteri) chiave esterna su persone la chiave primaria e costituita da (figlio,genitore). 65 / 67

66 Riepilogo e Sommario Example CREATE TABLE persone( id CHAR(2) PRIMARY KEY, nome VARCHAR(20) NOT NULL, reddito INT DEFAULT 0, eta SMALLINT, sesso CHAR CHECK(sesso= M OR sesso F )); CREATE TABLE genitori( figlio CHAR(2) REFERENCES persone(id), genitore CHAR(2) REFERENCES persone(id) PRIMARY KEY(figlio,genitore)); 66 / 67

67 Bibliografia ed Approfondimenti Bibliografia ed Approfondimenti R.A.Elmasri, S.B. Navathe. Sistemi di Basi di Dati Fondamenti: Capitolo 8 (8.1). Capitolo 8 (Data Types) e capitolo 5 (Data Definition) del manuale di PostgreSQL (http://www.postgresql.org/docs/manuals/) 67 / 67

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 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

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

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

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

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

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 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

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

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

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

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

Basi di Dati Relazionali

Basi di Dati Relazionali Corso di Laurea in Informatica Basi di Dati Relazionali a.a. 2009-2010 Laboratorio Ing. G. Laboccetta Dott.ssa. V. Policicchio Coadiutore: Dott.ssa D. Nicotera PROGETTAZIONE FISICA SQL-DDL OBIETTIVO: Rappresentare

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

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

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. 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

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

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

---------------------------------------------------------------------------- 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

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

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

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

Definizione e manipolazione dei dati in SQL

Definizione e manipolazione dei dati in SQL Definizione e manipolazione dei dati in SQL Nicola Vitacolonna Corso di Basi di Dati Università degli Studi di Udine 19 novembre 2013 Nota bene: nel presente documento, con il termine macchina virtuale,

Dettagli

DDL DML. Tipi di linguaggi per basi di dati. Si distinguono due categorie:

DDL DML. Tipi di linguaggi per basi di dati. Si distinguono due categorie: Tipi di linguaggi per basi di dati Si distinguono due categorie: DDL DML Linguaggi di definizione dei dati o data definition languages: utilizzati per definire gli schemi logici, esterni e fisici e le

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

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

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

Laboratorio di Basi di Dati Introduzione a SQL

Laboratorio di Basi di Dati Introduzione a SQL Laboratorio di Basi di Dati Introduzione a SQL Pierluigi Pierini Technolabs S.p.a. Pierluigi.Pierini@technolabs.it evoluzione e standards 1970 - E.F. Codd, A Relational Model of Data for Large Shared Data

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

Corso sul linguaggio SQL

Corso sul linguaggio SQL Corso sul linguaggio SQL Modulo L2B (SQL) 2.1 Comandi sui database 1 Prerequisiti Introduzione ai DB Linguaggi per database Tipi fondamentali di dati 2 1 Introduzione In questa Unità introduciamo il linguaggio

Dettagli

Introduzione a PostgreSQL

Introduzione a PostgreSQL Introduzione a PostgreSQL Un po di storia... 1977: all Università di Berkeley nasce progetto INGRES 1986: nasce The POSTGRES Project Leader: Prof. Michael Stonebraker 1989: DBMS Postgres (vers.1) 1990:

Dettagli

Descrizione del linguaggio SQL Definizione del database. Giovanna Rosone 02-03/03/2010

Descrizione del linguaggio SQL Definizione del database. Giovanna Rosone 02-03/03/2010 Descrizione del linguaggio SQL Definizione del database Giovanna Rosone 02-03/03/2010 Database Il termine Database indica l insieme delle informazioni presenti in uno specifico sistema informativo. E composto

Dettagli

Basi di dati Il linguaggio SQL

Basi di dati Il linguaggio SQL Basi di dati Il linguaggio SQL teoria e pratica con Microsoft Access Riepilogando Nelle basi di dati esiste 1. una parte invariante nel tempo, lo schema, costituita dalle caratteristiche dei dati (nomi

Dettagli

Basi di dati Il linguaggio SQL

Basi di dati Il linguaggio SQL Riepilogando Basi di dati Il linguaggio SQL Nelle basi di dati esiste 1. una parte invariante nel tempo, lo schema, costituita dalle caratteristiche dei dati (nomi degli attributi, domini, 2. una parte

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

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

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

SQL. Definizione dei da6 in SQL. SQL: "storia" CREATE TABLE: esempio. CREATE TABLE: esempio

SQL. Definizione dei da6 in SQL. SQL: storia CREATE TABLE: esempio. CREATE TABLE: esempio SQL Atzeni, Ceri, Paraboschi, Torlone Basi di da6 Originariamente Structured Query Language, ora "nome proprio" Linguaggio con varie funzionalità: DDL Data Defini6on Language (insieme di comandi per la

Dettagli

Linguaggio SQL Descriviamo la notazione usata nel seguito:

Linguaggio SQL Descriviamo la notazione usata nel seguito: Descriviamo la notazione usata nel seguito: i termini del linguaggio sono sottolineati; i termini variabili sono scritti in corsivo; le parentesi angolari (< >)permettono di isolare un termine della sintassi;

Dettagli

Basi di Dati. Programmazione e gestione di sistemi telematici

Basi di Dati. Programmazione e gestione di sistemi telematici Basi di Dati. Programmazione e gestione di sistemi telematici Coordinatore: Prof. Paolo Nesi Docenti: Prof. Paolo Nesi Dr.sa Michela Paolucci Dr. Emanuele Bellini SQL SQL = Structured Query Language Linguaggio

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

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

Lezione del modulo 7 SQL e database del giorno 04/05/2006 tot. ore 3. Lo Standard SQL

Lezione del modulo 7 SQL e database del giorno 04/05/2006 tot. ore 3. Lo Standard SQL Lezione del modulo 7 SQL e database del giorno 04/05/2006 tot. ore 3 Lo Standard SQL Il linguaggio SQL è un linguaggio non procedurale (o di tipo dichiarativo), divenuto, ormai da tempo, il linguaggio

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

Basi di dati e Sistemi informativi aziendali

Basi di dati e Sistemi informativi aziendali Sistemi informativi Linguaggio SQL: fondamenti Istruzione SELECT: fondamenti Interrogazioni nidificate Operatori insiemistici Istruzioni di aggiornamento Gestione delle tabelle 2 2007 Politecnico di Torino

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

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

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

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

Structured Query Language parte 1

Structured Query Language parte 1 Consorzio per la formazione e la ricerca in Ingegneria dell'informazione Structured Query Language parte 1 Come interrogare una base di dati relazionale ed avere la risposta esatta Docente: Gennaro Pepe

Dettagli

Structured Query Language. Informatica Generale - SQL Versione 1.0, aa 2005-2006 p.1/172

Structured Query Language. Informatica Generale - SQL Versione 1.0, aa 2005-2006 p.1/172 Structured Query Language Informatica Generale - SQL Versione 1.0, aa 2005-2006 p.1/172 Linguaggio SQL (1) Il linguaggio SQL, acronimo di Structured Query Language è un linguaggio per la definizione e

Dettagli

DBMS e SQL. 74.1 Introduzione ai DBMS

DBMS e SQL. 74.1 Introduzione ai DBMS 773 DBMS e SQL Capitolo 74 74.1 Introduzione ai DBMS............................. 773 74.1.1 Caratteristiche fondamentali.................... 773 74.1.2 Modello relazionale.......................... 774

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

nuove voci tutti i giorni, e non si cancellano o aggiornano voci tutti i giorni), non si avverte l esigenza di avvalersi di un sistema informatico.

nuove voci tutti i giorni, e non si cancellano o aggiornano voci tutti i giorni), non si avverte l esigenza di avvalersi di un sistema informatico. LE BASI DI DATI Generalità Un sistema informatico serve ad elaborare informazioni. Esso è giustificato, anzi è necessario, quando le informazioni da memorizzare sono tante e le elaborazioni da eseguirvi

Dettagli

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

OR true null false true true true true null true null null false true null false NOT 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,

Dettagli

SQL. (Structured Query Language) Eugenio Di Sciascio

SQL. (Structured Query Language) Eugenio Di Sciascio SQL (Structured Query Language) Eugenio Di Sciascio SQL come DDL e DML SQL non è solo un linguaggio di interrogazione Linguaggio di definizione e manipolazione dati DDL (Data Definition Language): consente

Dettagli

SQL Manuale introduttivo

SQL Manuale introduttivo SQL Manuale introduttivo SOMMARIO INTRODUZIONE... 3 TIPI DI DATI... 3 STRINGHE DI CARATTERI... 3 NUMERI... 3 DATA/ORA... 4 COSTANTI STRINGA... 4 COSTANTI NUMERICHE... 4 COSTANTI DATA/ORA... 5 NOTE SULLA

Dettagli

Basi di dati. Parte iii. 84 DBMS e SQL... 1073

Basi di dati. Parte iii. 84 DBMS e SQL... 1073 Parte iii Basi di dati 84 DBMS e SQL............................................................. 1073 84.1 Introduzione ai DBMS............................................... 1073 84.2 Questioni organizzative

Dettagli

Basi di dati. Parte v

Basi di dati. Parte v Parte v Basi di dati 74 DBMS e SQL....................................... 773 74.1 Introduzione ai DBMS........................... 773 74.2 Questioni organizzative generali dei DBMS comuni.782 74.3 Introduzione

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

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

Modello Relazionale. Sistemi di Elaborazione delle Informazioni. DB ed SQL. Modello relazionale: concetti di base

Modello Relazionale. Sistemi di Elaborazione delle Informazioni. DB ed SQL. Modello relazionale: concetti di base Sistemi di Elaborazione delle Informazioni DB ed SQL Prof. Silvio Vassallo Modello Relazionale Il modello relazionale si basa sul concetto di RELAZIONE tra insiemi di oggetti. Dati n insiemi A 1,A 2, A

Dettagli

Informatica B. Contenuti. Introduzione alle Basi di Dati e ai DBMS. Introduzione a dati e basi dati DBMS Modello dei dati

Informatica B. Contenuti. Introduzione alle Basi di Dati e ai DBMS. Introduzione a dati e basi dati DBMS Modello dei dati Informatica B Introduzione alle Basi di Dati e ai DBMS Contenuti Introduzione a dati e basi dati DBMS Modello dei dati Informazioni e dati Dato: elemento semanticamente significativo (data, codice, ecc.),

Dettagli

Appunti di MySql. Evoluzione di un tutorial di base di mysql, scritto da Etel Sverdlov.

Appunti di MySql. Evoluzione di un tutorial di base di mysql, scritto da Etel Sverdlov. Appunti di MySql Evoluzione di un tutorial di base di mysql, scritto da Etel Sverdlov. Indice generale avviare la shell mysql...2 comandi SQL per la gestione del database (DDL)...2 visualizzare l'elenco

Dettagli

Basi di dati. Parte iii. 84 DBMS e SQL... 489

Basi di dati. Parte iii. 84 DBMS e SQL... 489 Parte iii Basi di dati 84 DBMS e SQL.............................................................. 489 84.1 Introduzione ai DBMS................................................ 489 84.2 Questioni organizzative

Dettagli

http://technet.microsoft.com/it-it/library/bb500469.aspx Le versioni di SQL Server sono state molte; traggo le principali da Wikipedia:

http://technet.microsoft.com/it-it/library/bb500469.aspx Le versioni di SQL Server sono state molte; traggo le principali da Wikipedia: LEZIONE-TSQL-01 DDL (VER01 PAG. 1 / 11 LEZIONE-TSQL-01 DDL (VER01 T-SQL PROGRAMMAZIONE PARTE PRIMA MICROSOFT SQL SERVER IL PRODOTTO MICROSOFT SQL SERVER Le dispense SQL descrivono un generico SQL utilizzato

Dettagli

DB2 Universal Database (UDB) DB2 Universal Database (UDB)

DB2 Universal Database (UDB) DB2 Universal Database (UDB) DB2 Universal Database (UDB) Sistemi Informativi L-A Home Page del corso: http://www-db.deis.unibo.it/courses/sil-a/ Versione elettronica: DB2Presentazione2009.pdf Sistemi Informativi L-A DB2 Universal

Dettagli

Il Domino Character Il domino CHARACTER permette di definire attributi che contengono un singolo carattere o stringhe di caratteri di lunghezza

Il Domino Character Il domino CHARACTER permette di definire attributi che contengono un singolo carattere o stringhe di caratteri di lunghezza Linguaggio SQL (1) Il linguaggio SQL, acronimo di Structured Query Language è un linguaggio per la definizione e la manipolazione dei dati, sviluppato originariamente presso il laboratorio IBM a San Jose

Dettagli

L interfaccia a riga di comando di MySql

L interfaccia a riga di comando di MySql L interfaccia a riga di comando di MySql Una volta completata la procedura di installazione possiamo finalmente testare le funzionalità di MySQL. Sia che ci si trovi in ambiente Linux che Windows, l'interfaccia

Dettagli

Linguaggio SQL: fondamenti. Basi di dati. Elena Baralis Pag. 1. Linguaggio SQL: fondamenti. Sistemi informativi. Introduzione

Linguaggio SQL: fondamenti. Basi di dati. Elena Baralis Pag. 1. Linguaggio SQL: fondamenti. Sistemi informativi. Introduzione Sistemi informativi Istruzione : fondamenti Interrogazioni nidificate Operatori insiemistici Istruzioni di aggiornamento Gestione delle tabelle 2 al linguaggio SQL Istruzioni del linguaggio Notazione 4

Dettagli

Tool. Basi di Dati e Sistemi Informativi Prof. Marco Di Felice Dott.sa Sara Zuppiroli A.A. 2012-2013

Tool. Basi di Dati e Sistemi Informativi Prof. Marco Di Felice Dott.sa Sara Zuppiroli A.A. 2012-2013 Tool Basi di Dati e Sistemi Informativi Prof. Marco Di Felice Dott.sa Sara Zuppiroli A.A. 2012-2013 Basi di Dati e Sistemi Informativi () PostgreSQL A.A. 2012-2013 1 / 26 Gli strumenti che vedremo Basi

Dettagli

Lezione V. Aula Multimediale - sabato 29/03/2008

Lezione V. Aula Multimediale - sabato 29/03/2008 Lezione V Aula Multimediale - sabato 29/03/2008 LAB utilizzo di MS Access Definire gli archivi utilizzando le regole di derivazione e descrivere le caratteristiche di ciascun archivio ASSOCIAZIONE (1:1)

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. 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

Basi di dati. SQL: Amministrazione e Viste. Prof.ssa Rosalba Giugno Dott. Aurelio Giudice

Basi di dati. SQL: Amministrazione e Viste. Prof.ssa Rosalba Giugno Dott. Aurelio Giudice Basi di dati SQL: Amministrazione e Viste Prof.ssa Rosalba Giugno Dott. Aurelio Giudice SQL per definire ed amministrare Ad ogni utente tipicamente viene associata una base di dati, creata dall amministratore

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

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

Preparazione. Introduzione a MySQL: costruzione di una base di dati e gestione degli accessi. Accesso all area condivisa. Avvio Server MySQL

Preparazione. Introduzione a MySQL: costruzione di una base di dati e gestione degli accessi. Accesso all area condivisa. Avvio Server MySQL Introduzione a MySQL: costruzione di una base di dati e gestione degli accessi Stefania Marrara Elisa Quintarelli Lezione 1 2 ore a.a 2004/05 Preparazione Accesso all area condivisa Start -> Programs ->MySQL

Dettagli

Il DBMS Oracle. Express Edition. Donatella Gubiani e Angelo Montanari

Il DBMS Oracle. Express Edition. Donatella Gubiani e Angelo Montanari Gubiani & Montanari Il DBMS Oracle 1 Il DBMS Oracle Express Edition Donatella Gubiani e Angelo Montanari Il DBMS Oracle Il DBMS Oracle Oracle 10g Express Edition Il DBMS Oracle (nelle sue versioni più

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

Esercitazione: Il DBMS MySQL

Esercitazione: Il DBMS MySQL Laurea in Ingegneria Informatica SAPIENZA Università di Roma Insegnamento di Basi di Dati Esercitazione: Il DBMS MySQL Marco Console Aspetti Organizzativi Marco Console Sito: www.dis.uniroma1.it/~console

Dettagli

70555 Informatica 3 70777 Sicurezza 2. 70555 Mario Rossi 70777 Anna Bianchi. Esempio istanza:

70555 Informatica 3 70777 Sicurezza 2. 70555 Mario Rossi 70777 Anna Bianchi. Esempio istanza: DOMANDE 1) Definire i concetti di schema e istanza di una base di dati, fornendo anche un esempio. Si definisce schema di una base di dati, quella parte della base di dati stessa che resta sostanzialmente

Dettagli

Domini elementari in SQL

Domini elementari in SQL SQL SQL è un acronimo per Structured Query Language. Fu sviluppato originalmente come linguaggio per il DBMS System R dall IBM Research Laboratory (San Jose, California) nei tardi anni settanta. Al giorno

Dettagli

GUIDA BASE ALL SQL by DaD

GUIDA BASE ALL SQL by DaD GUIDA BASE ALL SQL by DaD Introduzione L'SQL, è un linguaggio per database anche se sarebbe meglio definirlo un sublinguaggio in quanto a differenza dei linguaggi veri e propri non possiede alcun comando

Dettagli

Il linguaggio SQL. ing. Alfredo Cozzi 1

Il linguaggio SQL. ing. Alfredo Cozzi 1 Il linguaggio SQL ing. Alfredo Cozzi 1 Il linguaggio SQL Il linguaggio SQL (Structured Query Language) è nato con l intento di soddisfare alle seguenti richieste nei db relazionali: - definire e creare

Dettagli

Abilità Informatiche A.A. 2010/2011 Lezione 8: Basi di Dati. Facoltà di Lingue e Letterature Straniere

Abilità Informatiche A.A. 2010/2011 Lezione 8: Basi di Dati. Facoltà di Lingue e Letterature Straniere Abilità Informatiche A.A. 2010/2011 Lezione 8: Basi di Dati Facoltà di Lingue e Letterature Straniere Base di dati (accezione generica, metodologica) Insieme organizzato di dati utilizzati per il supporto

Dettagli

Il Linguaggio SQL. Il Linguaggio SQL

Il Linguaggio SQL. Il Linguaggio SQL Il Linguaggio SQL 23 Il Linguaggio SQL SQL è l acronimo di Standard Query Language e identifica un linguaggio di interrogazione (gestione) per basi di dati relazionali. Le sue origini risalgono alla fine

Dettagli

Basi di Da( MySQL & MySQL Workbench. Anna Monreale

Basi di Da( MySQL & MySQL Workbench. Anna Monreale Basi di Da( MySQL & MySQL Workbench Anna Monreale MySQL MySQL è un DBMS gratuito ed open- source (h@p://www.mysql.com) MySQL può essere uilizzato in Windows, Linux, MacOS X. MySQL è un RDBMS (relaional

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

Esercitazioni di Basi di Dati

Esercitazioni di Basi di Dati Esercitazioni di Basi di Dati A.A. 2008-09 Dispense del corso Utilizzo base di pgadmin III Lorenzo Sarti sarti@dii.unisi.it PgAdmin III PgAdmin III è un sistema di progettazione e gestione grafica di database

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

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

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

Sistemi Informativi Aziendali II

Sistemi Informativi Aziendali II Modulo 2 Sistemi Informativi Aziendali II 1 Corso Sistemi Informativi Aziendali II - Modulo 2 Modulo 2 La gestione delle informazioni strutturate nell impresa: La progettazione di un Data Base; Le informazioni

Dettagli

CORSO INTEGRATO DI ELEMENTI DI INFORMATICA, LABORATORIO DI INFORMATICA RETI INTERNET Polo C. Base dei dati. Anno accademico 2009/2010-2^ anno Polo C

CORSO INTEGRATO DI ELEMENTI DI INFORMATICA, LABORATORIO DI INFORMATICA RETI INTERNET Polo C. Base dei dati. Anno accademico 2009/2010-2^ anno Polo C CORSO INTEGRATO DI ELEMENTI DI INFORMATICA, LABORATORIO DI INFORMATICA RETI INTERNET Polo C Base dei dati Anno accademico 2009/2010-2^ anno Polo C Docenti: Prof. Ing. Paolo Arena Prof. Ing. Giovanni Caffarelli

Dettagli

Archivi e Basi di Dati

Archivi e Basi di Dati Archivi e Basi di Dati A B C File Programma 1 Programma 2 A B C File modificati Programma 1 DBMS DB Programma 2 Informatica Generale (CdL in E&C), A.A. 2000-2001 55 Problemi nella gestione di archivi separati

Dettagli

Data base relazionale ed SQL. Modello relazionale dei data base e il linguaggio standard per la loro gestione

Data base relazionale ed SQL. Modello relazionale dei data base e il linguaggio standard per la loro gestione Data base relazionale ed SQL Modello relazionale dei data base e il linguaggio standard per la loro gestione Contenuti Modello relazionale Cenni sulla progettazione di un data base Normalizzazione delle

Dettagli

LINGUAGGIO SQL. Introduzione

LINGUAGGIO SQL. Introduzione LINGUAGGIO SQL Introduzione Il linguaggio SQL (Structured Query Language) è un linguaggio di tipo non procedurale o di tipo dichiarativo e rappresenta lo standard per l'interrogazione delle basi di dati

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