[successivo] [precedente] [inizio] [fine] [indice generale] [indice ridotto] [translators] [docinfo] [indice analitico] [volume] [parte]
Prima di poter iniziare a eseguire gli esercizi di questa parte, dedicata alle basi di dati e al linguaggio SQL, è necessario verificare di disporre degli strumenti adatti ed essere sicuri di saperli utilizzare.
Per facilitare l'esecuzione di queste esercitazioni, sia gli esercizi, sia le verifiche sono realizzabili con SQLite, attraverso il programma sqlite3.
Gli esercizi prevedono l'uso di basi di dati personali, ognuna contenuta tutta in un file.
Le verifiche associate a queste esercitazioni portano a produrre dei fogli stampati, che gli studenti devono avere la cura di controllarle in base a quanto indicato nella traccia delle verifiche stesse, prima della consegna all'insegnante.
Per poter svolgere gli esercizi e le verifiche, ogni studente deve essere in grado di scrivere e modificare file di testo, con un programma adatto (per esempio va bene il programma Gedit). In questi file di testo vanno inserite le istruzioni SQL necessarie allo svolgimento del lavoro; per evitare confusione, i file che contengono codice SQL vengono nominati con l'estensione .sql
.
Per eseguire le istruzioni SQL contenute in un file, si usa il programma sqlite3 nel modo seguente:
$
sqlite3 file_db < file_sql
[Invio]
In questo caso, le istruzioni contenute nel file file_sql, vengono applicate alla base di dati contenuta nel file file_db.
Per essere certi di sapere usare gli strumenti occorre fare una prova. Si realizzi il file di testo denominato prova-istruzioni.sql
, contenente quanto segue, sostituendo le metavariabili cognome, nome, classe e data con qualcosa di appropriato:
|
Una volta salvato il file con il nome stabilito, lo si esegue nella base di dati contenuta nel file prova.db
. Dal momento che il file prova.db
non esiste, essendo la prima volta che viene utilizzato questo nome, l'esecuzione delle istruzioni comporta automaticamente la creazione della base di dati relativa:
$
sqlite3 prova.db < prova-istruzioni.sql
[Invio]
Se non si vedono segnalazioni di alcun genere, le istruzioni contenute nel file prova-istruzioni.sql
sono state eseguite tutte con successo.
Le istruzioni contenute nel file prova-istruzioni.sql
servono a produrre una relazione, denominata Prova, contenente alcuni attributi (Codice, Cognome e Nome).
Se il file contenente le istruzioni SQL contiene degli errori, o viene eseguito quando ciò non deve essere fatto, è probabile vedere apparire dei messaggi, che vanno letti attentamente. Per esempio, se venisse eseguito nuovamente il file prova-istruzioni.sql
nella stessa base di dati, si otterrebbe una segnalazione che avvisa del fatto che la relazione Prova esiste già (e non può essere creata nuovamente):
$
sqlite3 prova.db < prova-istruzioni.sql
[Invio]
CREATE TABLE Prova (Codice INTEGER, Cognome VARCHAR(60), Nome VARCHAR(60)); SQL error: table Prova already exists |
Il programma sqlite3 può essere usato anche interattivamente. Per farlo, si avvia senza indicare il file contenente le istruzioni SQL. Si proceda in questo modo:
$
sqlite3 prova.db
[Invio]
A questo punto appare l'invito del programma sqlite3, che indica la sua attesa di comandi o di istruzioni SQL, digitati direttamente:
sqlite>
Con il comando .schema (si osservi il fatto che il comando inizia con un punto) è possibile visualizzare l'elenco delle relazioni esistenti, in forma di istruzione SQL. Si proceda inserendo questo comando:
sqlite>
.schema
[Invio]
CREATE TABLE Prova (Codice INTEGER, Cognome VARCHAR(60), Nome VARCHAR(60)); |
Si proceda inserendo l'istruzione necessaria a eliminare la relazione Prova creata poco prima:
sqlite>
DROP TABLE Prova;
[Invio]
Si conclude con il funzionamento di sqlite3 con il comando .quit:
sqlite>
.quit
[Invio]
Prima di passare ai capitoli successivi, vanno eliminati i file prova-istruzioni.sql
e prova.db
, che non servono più.
In questi esercizi, vengono creati una serie di file, che qui vengono elencati in ordine alfabetico, con il riferimento alla sezione in cui sono utilizzati.
cancella-articoli.sql
, 513.3
creazione-articoli.sql
, 505.3
creazione-causali.sql
, 505.4
creazione-clienti.sql
, 505.6
creazione-fornitori.sql
, 505.5
creazione-movimenti.sql
, 505.7
grilletti-articoli.sql
, 514.2
grilletti-causali.sql
, 514.1
grilletti-movimenti-articoli.sql
, 515.1
grilletti-movimenti-causali.sql
, 515.3
grilletti-movimenti-clienti.sql
, 515.2
grilletti-movimenti-fornitori.sql
, 515.4
grilletti-movimenti.sql
, 514.3
grilletto-valorizzazione-scarichi.sql
, 518.2
interrogazione-articoli-01.sql
, 506.4
interrogazione-articoli-02.sql
, 507.2
interrogazione-articoli-03.sql
, 508.2
interrogazione-articoli-04.sql
, 508.3
interrogazione-causali-01.sql
, 507.4
interrogazione-causali-02.sql
, 508.4
interrogazione-clienti-01.sql
, 507.3
interrogazione-fornitori-clienti-01.sql
, 506.5
interrogazione-movimenti-causali-01.sql
, 509.3
interrogazione-movimenti-causali-02.sql
, 510.2
interrogazione-movimenti-causali-clienti-01.sql
, 509.4
interrogazione-movimenti-causali-clienti-02.sql
, 509.5
interrogazione-movimenti-causali-clienti-03.sql
, 510.3
modifica-articoli.sql
, 512.3
modifica-clienti-fornitori.sql
, 512.4
prova-creazione-articoli.sql
, 505.1
prova-interrogazione-movimenti-articoli.sql
, 509.1, 509.2, 510.1
prova-interrogazione-movimenti-vu.sql
, 516.1
prova-istruzioni.sql
, 504
prova-stampa-articoli-e-causali-01.sql
, 506.3
prova-vista-listino.sql
, 511.1
prova-vista-resi.sql
, 511.2
prova.db
, 504
vista-acquisti.sql
, 511.3
vista-costo-medio-valido.sql
, 518.1
vista-situazione-magazzino-1.sql
, 517.2
vista-situazione-magazzino-2.sql
, 517.3
vista-situazione-magazzino-3.sql
, 517.4
vista-vendite.sql
, 511.4
Appunti di informatica libera 2006.07.01 --- Copyright © 2000-2006 Daniele Giacomini -- <daniele (ad) swlibero·org>
Dovrebbe essere possibile fare riferimento a questa pagina anche con il nome preparazione_1.htm
[successivo] [precedente] [inizio] [fine] [indice generale] [indice ridotto] [translators] [docinfo] [indice analitico]