Database Modulo 3 DEFINIRE LE CHIAVI

Похожие документы
5.3 TABELLE RECORD Inserire, eliminare record in una tabella Aggiungere record Eliminare record

Access. Microsoft Access. Aprire Access. Aprire Access. Aprire un database. Creare un nuovo database

Database 1 biblioteca universitaria. Testo del quesito

7. Microsoft Access. 1) Introduzione a Microsoft Access

Esercizio data base "Biblioteca"

CREAZIONE DI UN DATABASE E DI TABELLE IN ACCESS

Microsoft Access. Microsoft Access

Iniziativa Comunitaria Equal II Fase IT G2 CAM Futuro Remoto. Approfondimento SOFTWARE PER L ARCHIVIAZIONE

Esercizio sui data base "Gestione conti correnti"

1. I database. La schermata di avvio di Access

Cos è ACCESS? E un programma di gestione di database (DBMS) Access offre: un ambiente user frendly da usare (ambiente grafico)

MODULO 5 Basi di dati (database)

. A primi passi con microsoft a.ccepss SommarIo: i S 1. aprire e chiudere microsoft access Start (o avvio) l i b tutti i pro- grammi

corso di Access MICROSOFT ACCESS Docente: Andrea Mereu Università degli studi di Cagliari 16 aprile 9 maggio 2012

Corso di Archivistica

INFORMATICA PER LE APPLICAZIONI ECONOMICHE PROF.SSA BICE CAVALLO

Per ulteriori informazioni, vedere l'articolo Nozioni fondamentali della progettazione di database.

Che cos'è un modulo? pulsanti di opzione caselle di controllo caselle di riepilogo

Sistema Informativo Gestione Fidelizzazione Clienti MANUALE D USO

Modulo 5 Database. Diapo: 1

I database relazionali (Access)

Università degli Studi di Ferrara - A.A. 2014/15 Dott. Valerio Muzzioli ORDINAMENTO DEI DATI

Microsoft Access 2000

Esercitazione n. 9: Creazione di un database relazionale

On-line Corsi d Informatica sul web

INFORMATICA PER L IMPRESA (Docente Prof. Alfredo Garro)

Database 3 affitto veicoli. Testo del quesito

Modulo 1. Database: concetti introduttivi

CORSO ACCESS PARTE II. Esistono diversi tipi di aiuto forniti con Access, generalmente accessibili tramite la barra dei menu (?)

Organizzazione delle informazioni: Database

Relazioni tra tabelle

Esame di Informatica CHE COS È UN FOGLIO ELETTRONICO CHE COS È UN FOGLIO ELETTRONICO CHE COS È UN FOGLIO ELETTRONICO. Facoltà di Scienze Motorie

Introduzione. Alberto Fortunato Pag. 1 di 137

1. Le macro in Access 2000/2003

5.2 UTILIZZO DELL APPLICAZIONE

Passo 2: avviare Access e creare una tabella per ogni tipo di entità Costruire la tabella per l entità cliente.

Access - Lezione 02. Basi di dati. Parte seconda. (Per andare direttamente su un argomento, fare clic con il mouse sul titolo nell indice sottostante)

5.2.1 RELAZIONI TRA TABELLE Creare una relazione uno-a-uno, uno-a-molti tra tabelle 9

Il sofware è inoltre completato da una funzione di calendario che consente di impostare in modo semplice ed intuitivo i vari appuntamenti.

Uso delle basi di dati DBMS. Cos è un database. DataBase. Esempi di database

I DATABASE Database relazionale

Obiettivi del corso. Creare, modificare e formattare un semplice database costituito da tabelle, query, maschere e report utilizzando Access 2000.

Monitor Orientamento. Manuale Utente

Microsoft Access Maschere

Pagina 1 di 10

Le query. Lezione 6 a cura di Maria Novella Mosciatti

(A) CONOSCENZA TERMINOLOGICA (B) CONOSCENZA E COMPETENZA (C) ESERCIZI DI COMPRENSIONE

Ci sono molti vantaggi nel mettere in relazione le

Maschere. Microsoft Access. Maschere. Maschere. Maschere. Aprire una maschere. In visualizzazione foglio dati: Maschere

SendMedMalattia v Manuale d uso

Capitolo IX Esercitazione n. 9: Creazione di un database relazionale

DISPENSA PER MICROSOFT WORD 2010

Database Modulo 2. Le operazioni di base

LA GESTIONE DELLE VISITE CLIENTI VIA WEB

LA RICLASSIFICAZIONE DEI SALDI CONTABILI CON MICROSOFT ACCESS 2007

On-line Corsi d Informatica sul Web

% " #0 " - $ 2 ; 1 <? ; "1 "$" 1"" " A ; 1 B ( $10 -# C.?@@??9@ D ; 1 "$ 2/ )$1 $$ - (%) (%)# $ 1 2 E$#"" )(F. *$ E#! $( $ F; "5!

Database Manager Guida utente DMAN-IT-01/09/10

Gestione delle informazioni necessarie all attività di validazione degli studi di settore. Trasmissione degli esempi da valutare.

Figura 1 Le Icone dei file di Excel con e senza macro.

IL SISTEMA OPERATIVO

Dispense Corso Access

UTILIZZO DEL MODULO DATA ENTRY PER L IMPORTAZIONE DEI DOCUMENTI (CICLO PASSIVO)

Esportare dati da Excel

WORD per WINDOWS95. Un word processor e` come una macchina da scrivere ma. con molte più funzioni. Il testo viene battuto sulla tastiera

Le query di raggruppamento

FPf per Windows 3.1. Guida all uso

GUIDA UTENTE BILLIARDS COUNTER (Vers )

La Stampa Unione. Individuare la lista indirizzi per la Stampa Unione

Come costruire una presentazione. PowerPoint 1. ! PowerPoint permette la realizzazione di presentazioni video ipertestuali, animate e multimediali

Figura 54. Visualizza anteprima nel browser

Università di L Aquila Facoltà di Biotecnologie Agro-alimentari

Access. P a r t e p r i m a

EXCEL PER WINDOWS95. sfruttare le potenzialità di calcolo dei personal computer. Essi si basano su un area di lavoro, detta foglio di lavoro,

Aggiornamento programma da INTERNET

Il foglio elettronico. Excel PARTE

CREAZIONE DI UN DB RELAZIONALE IN ACCESS

MANUALE PARCELLA FACILE PLUS INDICE

BARCODE. Gestione Codici a Barre. Release 4.90 Manuale Operativo

IMPOSTARE UNA MASCHERA CHE SI APRE AUTOMATICAMENTE

Sviluppare un DB step by step

MODULO 5 BASI DI DATI

Database. Si ringrazia Marco Bertini per le slides

DENUNCE EDILCONNECT GUIDA COMPILAZIONE

Progettazione di Database. Un Esempio

Database e Microsoft Access. Ing. Antonio Guadagno

DBMS. Esempi di database. DataBase. Alcuni esempi di DBMS DBMS. (DataBase Management System)

A destra è delimitata dalla barra di scorrimento verticale, mentre in basso troviamo una riga complessa.

PowerPoint 2007 Le funzioni

La prima tabella da creare è quella relativa all elenco delle modalità mediante le quali è possibile identificare la corrispondenza (Posta

PIANO DI TUTELA DELLE ACQUE DELLA SICILIA (di cui all'art. 121 del Decreto Legislativo 3 aprile 2006, n 152)

Manuale di istruzioni sulle maschere per il calcolo del punteggio e del voto (unico) degli studenti che sostengono la Prova nazionale 2011

Access INTRODUZIONE. Cos'è un Database? Probabilmente il modo migliore per spiegarlo è attraverso un esempio: una rubrica telefonica.

CREAZIONE DI UN AZIENDA

MICROSOFT ACCESS. Fabrizio Barani 1

GESGOLF SMS ONLINE. Manuale per l utente

Транскрипт:

Database Modulo 3 DEFINIRE LE CHIAVI

Nell organizzazione di un archivio informatizzato è indispensabile poter definire univocamente le informazioni in esso inserite. Tale esigenza è abbastanza ovvia se si considerano archivi come quelli anagrafici, all interno dei quali si p r o d u c o n o s o v e n t e c a s i d i omonimia tra individui. 2

La ricerca dei dati in maniera univoca senza incorrere in casi di omonimia potrà essere effettuata attraverso l inserimento di un ulteriore campo, il cui tipo di dato rispetti l univocità dei record: questo campo è definito CAMPO CHIAVE 3

Nel caso della biblioteca, ci troviamo in presenza di un altro problema. I n f a t t i, r i s p e t t o a l l i m p o s t a z i o n e precedentemente data alla tabella, le informazioni relative alla localizzazione dei volumi in eventuali scaffalature non sono sufficienti a definirli univocamente: non è infatti specificato il volume all interno dello scaffale e della fila indicata. 4

Sarà opportuno, anche in vista della gestione dei prestiti dei volumi, indicarli univocamente all interno della biblioteca, attraverso una numerazione progressiva. In questo modo ogni volume all interno dell archivio è definito in modo univoco non ci sarà nessun altro volume identico, se non quello contenuto nello scaffale 5 fila 3. 5

L identificazione univoca degli elementi all interno di un archivio (tabella di Access) consiste appunto nella definizione di una chiave primaria. 6

I n M i c r o s o f t A c c e s s t a l e procedura può essere effettuata sia durante la definizione della tabella, contemporaneamente alla pianificazione dei campi, sia in fase di salvataggio della struttura creata. 7

Come già accennato precedentemente, quando si chiude la finestra della struttura di una tabella, Microsoft Access apre una finestra di dialogo all interno della quale avvisa della mancata definizione di una chiave primaria. 8

A t t r a v e r s o t a l e f i n e s t r a, cliccando con il tasto sinistro del mouse sul bottone Si, verrà automaticamente inserito un campo di tipo contatore, che è la più semplice delle chiavi che definiscono univocamente i record inseriti. 9

Estendendo il discorso ad archivi più complessi, caratterizzati cioè da un numero di campi e di record più elevato, sarà cura del progettista del database creare i campi chiave che svolgano il ruolo di definizione univoca delle informazioni. 10

Un esempio che riassume più di tutti l esigenza di univocità dei record, è l anagrafe tributaria. Infatti, in tale archivio non si devono assolutamente confondere i diversi contribuenti; per questa ragione è stata introdotta una chiave primaria molto efficiente (?) che viene associata a ciascun cittadino, praticamente dalla nascita: il Codice Fiscale. 11

Tale codice è diverso per ciascun contribuente, indipendentemente dal suo sesso, età o residenza ed ingloba informazioni anagrafiche opportunamente integrate da un carattere di controllo (il 16.mo) che ne verifica la correttezza. 12

L efficienza di tale chiave ha indotto, recentemente diversi enti e strutture pubbliche ad utilizzare il Codice Fiscale come informazione chiave nell ambito dei loro archivi. 13

Per attribuire il valore di chiave primaria ad un campo, tra quelli già definiti all interno di una tabella, che rispetti le caratteristiche di univocità citate sarà sufficiente (operando in modalità Struttura della tabella) selezionare il campo (la riga relativa) e cliccare sul bottone contraddistinto dalla chiave posto al centro della barra degli strumenti. Per indicare l avvenuta attribuzione apparirà, accanto all etichetta del campo, il simbolo della chiave. 14

15

In alternativa è possibile, agendo col tasto destro del mouse sul campo desiderato, impostare la chiave primaria selezionando la relativa voce nel menu contestuale: 16

Una corretta gestione del database richiede la creazione di un indice che permetta di reperire ed ordinare i record più rapidamente. In Microsoft Access gli indici di una tabella sono utilizzati come quelli di un libro: per trovare una voce, ad esempio, ne viene ricercata la posizione nell indice. 17

E possibile creare indici basati su un campo singolo o su più campi, i c.d. indici multicampo. Questi ultimi consentono di fare distinzione tra record in cui il primo campo potrebbe contenere lo stesso valore; una tabella anagrafica indicizzata per cognome e nome, risulterà ordinata nel seguente modo: 18

COGNOME NOME COGNOME NOME Bianchi Umberto Bianchi Filippo Bianchi Filippo Bianchi Umberto Rossi Antonio Rossi Antonio Verdi Mario Verdi Mario Tabella indicizzata solo rispetto al campo Cognome Tabella con indice multicampo Cognome, Nome 19

Quando si ordina una tabella in base ad un indice multicampo, l ordinamento sarà, quindi, eseguito in base al primo campo definito per l indice. Se nel primo campo sono presenti r e c o r d c o n v a l o r i d u p l i c a t i, l ordinamento è seguito in base al secondo campo definito per l indice e così via. 20

La praticità degli indici sta nel fatto che permettono di reperire rapidamente informazioni all interno di un archivio, attraverso l ordinamento logico che l utente attribuisce ad uno o più campi. 21

La chiave primaria di una tabella è indicizzata automaticamente, mentre non è possibile indicizzare un campo con un tipo di dati: Memo Collegamento ipertestuale 22

Per gli altri campi è consigliabile l indicizzazione se il tipo di dati del campo è: Testo Numerico Valuta Data/ora 23

Se molti valori nel campo sono identici, è possibile che l indice non renda molto più veloce l esecuzione delle interrogazioni. 24

Quando si ordina una tabella in base a d u n i n d i c e m u l t i c a m p o, l ordinamento viene eseguito in base al primo campo definito per l indice: se nel primo campo sono presenti r e c o r d c o n v a l o r i d u p l i c a t i, l ordinamento viene eseguito in base al secondo campo definito per l indice, e così via. 25

Per creare un indice a campo singolo la procedura da seguire in Microsoft Access è la seguente: 26

aprire una tabella esistente nella modalità Visualizzazione Struttura cliccando sul tasto ; nella parte superiore della finestra selezionare (facendo un clic con il tasto sinistro del mouse) il campo per il quale si desidera creare l indice; nella parte inferiore della finestra, fare clic sulla casella della proprietà Indicizzato, quindi selezionare Si (Duplicati ammessi) oppure No (Duplicati non ammessi). 27

La scelta implicherà la possibilità o meno - in fase di inserimento dei dati - di avere diversi record con il campo indicizzato contenente lo stesso valore; quindi, si selezionerà l opzione Si (Duplicati non ammessi) per assicurare che in quel campo non siano presenti due record contenenti gli stessi dati. 28

TIPI DI CHIAVI E DI INDICI 29

La chiave primaria Un DBMS relazionale come Microsoft Access consente di trovare velocemente e unire le informazioni memorizzate in tabelle diverse utilizzando query, maschere e report. A questo scopo è necessario che ogni tabella includa un campo o un set di campi che identifichi in modo univoco ogni record memorizzato nella tabella: queste informazioni vengono definite chiave primaria della tabella. 30

La chiave primaria Dopo aver stabilito la chiave primaria per una tabella, per assicurare l'univocità verrà impedito l'inserimento di valori duplicati o Null (valore che indica dati mancanti o sconosciuti in un campo) nei campi chiave primaria. 31

Tipi di chiave primaria In Microsoft Access è possibile definire tre tipi di chiavi primarie: - chiave primaria contatore - chiave primaria a campo singolo - chiave primaria multicampo 32

Chiave primaria CONTATORE È possibile impostare un campo Contatore per immettere automaticamente un numero sequenziale ogni volta che viene aggiunto un record alla tabella. La definizione di tale campo come chiave primaria di una tabella è il modo più semplice di creare una chiave primaria. 33

Chiave primaria CONTATORE Se, prima di salvare una tabella appena creata, non viene impostata una chiave primaria, verrà richiesto se si desidera crearne una: se si sceglie Sì, verrà creata una chiave primaria Contatore. 34

Chiave primaria A CAMPO SINGOLO Se si dispone di un campo che contiene valori univoci, quali codici o ID, tale campo può essere definito come chiave primaria. Se però il campo selezionato come chiave primaria contiene valori duplicati o Null (valori mancanti), la chiave primaria non verrà impostata. 35

Chiave primaria A CAMPO SINGOLO È possibile eseguire una Query ricerca duplicati per determinare quali record contengono dati duplicati. Se i valori duplicati non possono essere eliminati con facilità modificando i dati, è possibile aggiungere un campo Contatore e impostarlo come chiave primaria oppure definire una chiave primaria multicampo. 36

Chiave primaria MULTICAMPO In situazioni in cui non può essere garantita l'univocità di ogni singolo campo, è possibile definire due o più campi come chiave primaria. La situazione più comune in cui ciò può verificarsi è nella tabella utilizzata per correlare altre due tabelle in una relazione molti-a-molti. Un esempio di questo tipo di tabella è la tabella Dettagli ordini che correla le tabelle Ordini e Prodotti. 37

La chiave primaria della tabella Dettagli ordini è composta da due campi: ID ordine e ID prodotto. Questa tabella può elencare molti prodotti e molti ordini, ma poiché ogni prodotto può essere riportato solo una volta per ordine, combinando i campi ID ordine e ID prodotto viene creata una chiave primaria appropriata. 38

IMPOSTARE O MODIFICARE LA CHIAVE PRIMARIA 39

IMPOSTARE UNA CHIAVE PRIMARIA Aprire una tabella in visualizzazione Struttura. Selezionare il campo o i campi che si desidera definire come chiave primaria: - per selezionare un campo, fare clic sul selettore di righe del campo desiderato; - per selezionare più campi, tenere premuto CTRL, quindi fare clic sul selettore di righe di ciascun campo. Fare clic sul pulsante Chiave primaria 40

È possibile specificare una chiave primaria per un campo che già contiene dei dati, ma se nel campo vengono trovati valori duplicati o Null, quando si salva la tabella verrà generato un messaggio di errore. 41

Nel caso venga visualizzato questo messaggio, si hanno a disposizione tre possibilità: 1.utilizzare una Query ricerca duplicati per individuare i record con valori duplicati o mancanti e quindi modificare il campo per rimuoverli; 2.scegliere un campo diverso; 3.aggiungere un campo Contatore e impostarlo come chiave primaria. 42

I n u n a c h i a v e p r i m a r i a multicampo, l'ordine dei campi può rivelarsi molto importante. I campi, infatti, vengono ordinati in base all'ordine in cui appaiono nella visualizzazione Struttura della tabella. 43

Se si desidera impostare un ordine diverso, specificare prima i campi per la chiave primaria come d e s c r i t t o n e l l a p r o c e d u r a precedente, quindi fare clic sul pulsante Indici sulla barra degli strumenti per visualizzare la finestra Indici e riordinare i nomi dei campi per l'indice chiamato ChiavePrimaria. 44

RIMUOVERE LA CHIAVE PRIMARIA 45

Per poter rimuovere una chiave primaria utilizzata in una relazione, è necessario eliminare prima la relazione. 1. Aprire la tabella in visualizzazione Struttura. 2. Fare clic sul selettore di righe della chiave primaria corrente e quindi fare clic sul pulsante Chiave primaria sulla barra degli strumenti. 46

Questa procedura non elimina il campo o i campi definiti come chiave primaria, ma rimuove solo le caratteristiche della chiave primaria dalla tabella. In alcuni casi, è possibile che si debba rimuovere temporaneamente la chiave primaria. Quando si importano dei record in una tabella ad esempio, potrebbero crearsi dei record duplicati: fino a quando non vengono eliminati i duplicati, è opportuno rimuovere la chiave primaria. 47

CREARE UN INDICE È possibile creare un indice per un campo singolo o per una combinazione di campi per trovare e ordinare i record più rapidamente. 48

Si può: Definire un indice a campo singolo D e f i n i r e u n i n d i c e multicampo Visualizzare o modificare gli indici 49

CREARE UN INDICE A CAMPO SINGOLO 1. Aprire una tabella in visualizzazione Struttura. 2. Nella parte superiore della finestra, fare clic sul campo per il quale si desidera creare l'indice. 3. Nella scheda Generale nella parte inferiore della finestra fare clic sulla casella della proprietà Indicizzato, quindi fare clic su Sì (Duplicati possibili) oppure No (Duplicati impossibili): in quest ultimo caso ci si assicura che in quel campo non siano presenti due record contenenti gli stessi dati. 50

CREARE UN INDICE MULTICAMPO 1. Aprire una tabella in visualizzazione Struttura. 2. Fare clic sul pulsante Indici sulla barra degli strumenti. 3. Digitare un nome per l'indice nella prima riga vuota della colonna Nome indice. È possibile assegnare all'indice il nome di un campo indice o utilizzare un altro nome appropriato. 51

4. Nella colonna Nome campo fare clic sulla freccia e selezionare il primo campo per l'indice. 5. Nella riga successiva della colonna Nome campo selezionare il secondo campo per l'indice. Lasciare la colonna Nome indice vuota in quella riga. Ripetere questo passo fino a quando non sono stati selezionati tutti i campi che si desidera includere nell'indice. È possibile utilizzare un massimo di 10 campi. 6. Il criterio di ordinamento predefinito è Crescente. Selezionare Decrescente nella colonna Criterio ordinamento della finestra degli indici per ordinare i dati dei campi corrispondenti in senso decrescente. 52

VISUALIZZARE O MODIFICARE GLI INDICI 1. Aprire una tabella in visualizzazione Struttura. 2. Fare clic su Indici sulla barra degli strumenti. 3. Modificare gli indici o le proprietà relative. Per eliminare un indice, eliminare la relativa riga nella finestra degli indici. In questo modo verrà rimosso solo l'indice e non il campo. 53

ELIMINARE UN INDICE Gli indici rendono più veloci le ricerche ma possono anche rallentare gli aggiornamenti collettivi di record. Se si desidera rendere più veloci gli aggiornamenti collettivi di record, è consigliabile eliminare prima l'indice. L'eliminazione di un indice non implica l'eliminazione del campo o dei dati in esso contenuti. 54

Per eliminare un indice a campo singolo: 1. Aprire una tabella in visualizzazione Struttura. 2. Nella parte superiore della finestra fare clic sul campo di cui si desidera eliminare l'indice. 3. Nella scheda Generale nella parte inferiore della finestra fare clic nella casella della proprietà Indicizzato, quindi selezionare No. 55

Per eliminare un indice multicampo: 1. Aprire una tabella in visualizzazione Struttura. 2. Fare clic sul pulsante Indici sulla barra degli strumenti. 3. Nella finestra degli indici selezionare le righe contenenti l'indice da eliminare e premere il tasto CANC. In questo modo verrà rimosso solo l'indice e non il campo. 56

IMPEDIRE L'IMMISSIONE DI VALORI DUPLICATI IN UNA COMBINAZIONE DI CAMPI 1. Aprire una tabella in visualizzazione Struttura. 2. Creare un indice multicampo utilizzando i campi per i quali si desidera impedire l'immissione di valori duplicati. Dopo aver definito l'indice, lasciare aperta la finestra degli indici. 3. Nella parte superiore della finestra degli indici, fare clic sul nome del nuovo indice. 4. Nella parte inferiore della finestra degli indici, fare clic sulla casella della proprietà Univoco, quindi selezionare Sì. 57

IMPEDIRE L'IMMISSIONE DI VALORI DUPLICATI IN UN CAMPO 1. Aprire una tabella in visualizzazione Struttura. 2. Nella parte superiore della finestra fare clic sul campo per il quale si desidera impedire l'immissione di valori duplicati. 3. Nella parte inferiore della finestra, nella scheda Generale, fare clic nella casella della proprietà Indicizzato e selezionare Sì (Duplicati non ammessi). 58