Base di dati: differenze tra le versioni

Contenuto cancellato Contenuto aggiunto
Pil56-bot (discussione | contributi)
Web database: smistamento lavoro sporco
m Sistemazione fonti + tolgo doppie spaziature
 
(444 versioni intermedie di oltre 100 utenti non mostrate)
Riga 1:
{{Nota disambigua|il programma televisivo|[[Database (programma televisivodisambigua)]]|Database}}
{{Nota disambigua|i software per la gestione delle basi di dati|Database management system}}
{{NN|informatica|febbraio 2013}}
In [[informatica]], il termine '''''database''''', '''base di dati''' o '''banca dati''' (a volte abbreviato con il termine '''DB'''), indica un [[archivio elettronico|archivio]] [[dati]], o un insieme di archivi, in cui le [[informazione|informazioni]] in esso contenute sono strutturate e collegate tra loro secondo un particolare modello logico ([[Modello relazionale|relazionale]], [[Modello gerarchico|gerarchico]], [[Modello reticolare|reticolare]] o [[Modello a oggetti|a oggetti]]) e in modo tale da consentire la gestione/organizzazione efficiente dei dati stessi e l'interfacciamento con le richieste dell'utente attraverso i cosiddetti ''[[query language]]'' (''[[query]]'' di ricerca o interrogazione, inserimento, cancellazione, aggiornamento ecc.) grazie a particolari applicazioni [[software]] dedicate ([[DBMS]]), basate su un'architettura di tipo ''[[client-server]]''.
 
[[File:Noun project database 1276526 cc.svg|thumb|Simbolo generico usato per rappresentare una banca dati]]
==Descrizione==
===Generalità===
Il termine "database" può anche indicare contemporaneamente:
* l'archivio a livello fisico ([[hardware]]) cioè il sistema con i supporti di [[memoria (informatica)|memorizzazione]] (es. [[hard disk]]) che contengono i dati stessi e il [[processore]] per l'elaborazione di questi (''[[database server]]'');
* l'archivio a livello logico cioè i dati strutturati e la parte [[software]] cioè il ''[[database management system]]'' (DBMS) ovvero quella vasta categoria di [[applicazione (informatica)|applicazioni]] che consentono la creazione, manipolazione (gestione) ed interrogazione efficiente dei dati.
 
In [[informatica]] una '''base di dati''',<ref>{{Treccani|base-di-dati_(Enciclopedia-della-Matematica)|accesso=2022-07-19}}</ref> detta anche '''banca dati'''<ref>{{Treccani|banca-dati|Banca dati}}</ref> oppure '''''database''''' o '''''data base''''',<ref name=":0">{{Treccani|data-base|Data base|v=x}}</ref> è una collezione di dati organizzati immagazzinata e accessibile per via elettronica.<ref name=":0" />
Informalmente e impropriamente, la parola "database" viene spesso usata per indicare il ''database management system'' (DBMS) riferendosi dunque alla sola parte software. Un [[client]] di database [[lato client]] interagisce con il DBMS e quindi anche con il database in senso fisico.
 
Nel linguaggio comune e informale, la [[locuzione]] ''database'' tende a essere utilizzata impropriamente con varie sfumature di significato, di ordine più generale rispetto a "collezione astratta di dati":
Nei database più moderni, ovvero quelli basati sul modello relazionale, i dati vengono suddivisi per argomenti (in apposite tabelle) e poi tali argomenti vengono suddivisi per categorie (campi) con tutte le possibili operazioni di cui sopra. Tale suddivisione e funzionalità rende i database notevolmente più efficienti rispetto ad un archivio di dati creato ad esempio tramite [[file system]] di un [[sistema operativo]] su un [[computer]] almeno per la gestione di dati complessi.
 
* ''[[server|database server]]'': ovvero il [[hardware|sistema fisico]], comprendente sia le risorse di [[processore|elaborazione]] che di [[memoria (informatica)|memorizzazione]] necessarie al funzionamento della base di dati;
La diffusione dei database, e dei relativi sistemi DBMS di gestione, nei sistemi informativi moderni è enorme e capillare essendo un componente base di un [[sistema informativo]] attraverso il rispettivo [[sistema informatico]]: si pensi a tutte le attività commerciali di gestione di magazzino, gestione clienti, a sistemi di immagazzinamento di dati personali o pubblici nella [[pubblica amministrazione]] e nelle imprese private (es. [[banca|banche]] e [[azienda|aziende]]), contabilità ecc. I database sono presenti anche all'interno dell'[[architettura three-tier]] delle [[applicazione web|applicazioni web]] dove rappresenta il ''data layer'' ovvero la [[persistenza (informatica)|persistenza]] dei dati. La gestione e lo sviluppo dei database attraverso DBMS è diventata nel tempo una branca a tutti gli effetti dell'[[informatica]] moderna.
* ''[[database management system]]'': ovvero il [[sistema software]] necessario all'interfacciamento con la base di dati.<ref name=":0"/>
 
La progettazione delle basi di dati è un'attività complessa, che si basa sull'applicazione di [[formalismo matematico|tecniche formali]] in congiunzione a considerazioni pratiche derivate dalla natura dei dati stessi. In fase di progettazione si affrontano quindi problemi in materia di [[modellazione dei dati|modellazione]], [[codifica|rappresentazione]], [[memoria (informatica)|archiviazione]] e [[accessibilità (design)|accesso]] ai dati, oltre che della loro [[sicurezza informatica|sicurezza]], [[privatezza]] e [[integrità dei dati|integrità]]. Senza contare altre questioni di contorno che pertengono più propriamente ai [[DBMS]].<ref>{{cita|Atzeni 2018|pp. 197-202}}.</ref>
 
== Storia ==
{{S sezione|informatica}}
 
=== I modelli navigazionali ===
{{vedi anche|Modello gerarchico|Modello reticolare}}
 
Negli anni sessanta, con la crescita della capacità elaborativa dei calcolatori e la creazione di una serie di banche dati utilizzabili per diverse applicazioni, crebbe l'interesse nel fissare uno standard. [[Charles W. Bachman]], creatore del database navigazionale [[Integrated Data Store|IDS]], fondò il ''Database Task Group'' all'interno del gruppo ''[[CODASYL]]'': il team di lavoro dedicato alla creazione e standardizzazione del [[linguaggio di programmazione]] [[COBOL]]. Il lavoro del gruppo venne pubblicato nel 1971 e lo standard risultante prese il nome di "Approccio CODASYL", varie implementazioni commerciali apparvero sul mercato dopo poco tempo.
 
L'approccio CODASYL era basato sulla navigazione manuale in un insieme di dati disposti sotto forma di rete. Alla prima apertura del programma questo si trovava sul primo dato disponibile contenente, tra le altre cose, un [[Puntatore (programmazione)|puntatore]] ai dati successivi. Per trovare un dato il programma attraversava la serie di puntatori fino a trovare il dato corretto. Delle semplici ''[[query]]'' come "Trova tutte le persone nate in [[Svezia]]" richiedevano l'attraversamento dell'intero set di dati. Non esisteva alcuna funzione di ricerca; oggi questo potrebbe sembrare una limitazione, ma all'epoca, essendo i dati archiviati su [[nastro magnetico]], operazioni come quelle evidenziate sopra peggioravano ulteriormente il tempo di ricerca.
 
Nel 1968 [[IBM]] sviluppò un proprio [[DBMS]] chiamato [[Information Management System|IMS]]. IMS era lo sviluppo di un programma utilizzato nelle [[Programma Apollo|missioni Apollo]] sui calcolatori IBM [[System/360]] e utilizzava un sistema simile all'approccio CODASYL, con l'unica differenza di utilizzare un modello gerarchico anziché a rete.
 
Ambedue le soluzioni presero poi il nome di "banche dati navigazionali" a causa del metodo di consultazione che era stato previsto. Inoltre [[Charles Bachman]], in occasione della premiazione nel 1973 in cui gli venne conferito il [[Premio Turing]], presentò un lavoro intitolato ''Il programmatore come navigatore''. IMS è abitualmente classificato come una banca dati [[Modello gerarchico|gerarchica]], mentre IDS e IDMS (ambedue banche dati ''CODASYL''), CINCOMs e [[TOTAL]] sono classificati come banche dati [[Modello reticolare|reticolari]].
 
=== Il modello relazionale ===
{{vedi anche|Modello relazionale#Storia}}
 
[[Edgar F. Codd]] lavorava nella sede [[california]]na di [[IBM]] come ricercatore sull'allora nascente tecnologia dei [[dischi rigidi]] quando osservò l'inefficienza dell'approccio [[CODASYL]] con la nuova modalità di memorizzazione dei dati, inefficienza principalmente dovuta all'assenza di una funzione di ricerca.
Nel 1970 cominciò a produrre diversi documenti schematizzanti un nuovo approccio alla costruzione delle basi di dati, culminati nell'articolo "''A Relational Model of Data for Large Shared Data Banks''" ({{lett|Un modello relazionale dei dati per banche dati condivise di grandi dimensioni|lingua=it}}).
In questo articolo descrisse un nuovo sistema per archiviare e modificare grandi quantità di dati, basato su [[collezione (informatica)|collezioni]] di [[tuple]] di dimensione fissata ([[relazione (matematica)|relazioni]]) invece che [[albero (informatica)|alberi]] di ''[[record (database)|record]]''.<ref name="Codd 1970">{{cita|Codd 1970}}.</ref>
 
IBM cominciò a implementare questo modello in alcuni prototipi all'inizio degli anni settanta, a cominciare dal ''[[System R]]''. Agli inizi degli anni '80 il sistema aveva ormai dimostrato la sua superiorità rispetto a ''[[CODASYL]]'' e quindi IBM passò a sviluppare una versione commerciale di ''System R'', che prese il nome di "SQL/DS" prima e "[[IBM DB2|DB2]]" infine.<ref>{{cita web|url=https://www.ibm.com/it-it/topics/relational-databases#Breve+storia+dei+database+relazionali|titolo=Breve storia dei database relazionali|accesso=2024-03-18}}</ref>
Parallelamente il lavoro di Codd era stato ripreso dal mondo accademico attraverso il progetto [[INGRES]], dal quale nacquero numerosi spin-off commerciali che andarono a concorrere con IBM.<ref>{{cita pubblicazione|autore1=[[Michael Stonebraker]]|autore2=[[Lawrence A. Rowe]]|titolo=The design of POSTGRES|url=http://db.cs.berkeley.edu/papers/ERL-M85-95.pdf|p=4|rivista=SIGMOD '86: Proceedings of the 1986 ACM SIGMOD international conference on Management of data|editore=[[Association for Computing Machinery]]|città=Washington, DC|data=maggio 1986|lingua=en|ISBN=0897911911
|DOI=10.1145/16894}}</ref>
Nello stesso periodo venne anche standardizzato il linguaggio [[SQL]].
 
=== Il movimento NoSQL ===
{{vedi anche|NoSQL}}
 
Il termine NoSQL fu usato per la prima volta nel 1998 per descrivere una base di dati relazionale [[open source]] che non usava un'interfaccia [[SQL]].
L'autore [[Carlo Strozzi (informatico)|Carlo Strozzi]] dichiarò che "come movimento, NoSQL diparte in modo radicale dal modello relazionale, e quindi andrebbe chiamato in modo più appropriato NoREL, o qualcosa di simile".<ref>[http://www.strozzi.it/cgi-bin/CSA/tw7/I/en_US/NoSQL/Home%20Page Carlo Strozzi, NoSQL]</ref>
 
All'opposto di quanto si potrebbe pensare il movimento NoSQL non è contrario all'utilizzo di database relazionali. Il termine NoSQL infatti è acronimo di ''Not Only SQL'', a significare che esistono diversi casi d'uso per i quali il modello relazionale rappresenta una forzatura, ma tanti altri per i quali tale modello è ancora la soluzione migliore.
 
Il termine fu riutilizzato nel 2009 da un dipendente di [[Rackspace]], Eric Evans, quando [[Johan Oskarsson]] di [[Last.fm]] volle organizzare un evento per discutere di basi di dati distribuite open source<ref>[http://blog.knuthaugen.no/2010/03/a-brief-history-of-nosql.html A Brief History of NoSQL]</ref>.
Il nome era un tentativo di etichettare il crescente numero di database non relazionali e distribuiti che spesso non garantivano le classiche proprietà [[ACID]], a causa di vari compromessi formulati sulla base del [[teorema CAP]].
 
== Caratteristiche ==
 
=== Gestione delle informazioni ===
La base dibanca dati deve contenere anche le informazioni sulle loro rappresentazioni e sulle relazioni che li legano. Spesso, ma non necessariamente, una base dati contiene le seguenti informazioni:
Spesso, ma non necessariamente, una base dati contiene le seguenti informazioni:
 
* [[Strutture dati]] che velocizzano le operazioni frequenti, di solito a spese di operazioni meno frequenti.
* Collegamenti con dati esterni, cioè riferimenti a file locali o remoti non facenti parte deldella databasebanca dati.
* Informazioni di sicurezza, che autorizzano solo alcuni profili utente ada eseguire alcune operazioni su alcuni [[Tipo di dato|tipi di dati]].
* Programmi che vengono eseguiti, automaticamente o su richiesta di utenti autorizzati, per eseguire elaborazioni sui dati. Un tipico automatismo consiste nell'eseguire un [[Programma (informatica)|programma]] ogni volta che viene modificato un dato di un certo tipo.
 
In un sistema informatico, una base dibanca dati può essere usata direttamente dai programmi applicativi, interfacciandosi con il [[supporto di memorizzazione (insomma,]] agendo direttamente sui file). Questa strategia era adottata universalmente fino agli [[anni 1960|anni sessanta]], ed è tuttora impiegata quando i dati hanno una struttura molto semplice o quando sono elaborati da un solo programma applicativo.
Questa strategia era quella adottata universalmente fino agli [[anni 1960|anni sessanta]], ed è tuttora impiegata quando i dati hanno una struttura molto semplice, o quando sono elaborati da un solo programma applicativo.
 
DallaTuttavia dalla fine degli anni sessanta, tuttavia, per gestire basi dibanche dati complesse condivise da più applicazioni, si sono utilizzati appositi sistemi software, detti '''"sistemi per la gestione di basi di dati'''" (in inglese "[[Databasedatabase Managementmanagement Systemsystem]]" o "DBMS"). Uno dei vantaggi di questi sistemi è la possibilità di non agire direttamente sui dati, ma di vederne una rappresentazione concettuale.
 
La ricerca nel campo delle basi dibanche dati studia le seguenti problematiche:
* Progettazione di basi dibanche dati.
* Progettazione e implementazione di DBMS.
* Interpretazione (o analisi) di dati contenuti innelle databasebanche dati.
 
Le basi dibanche dati spesso fanno uso di tecnologie derivate da altre branche dell'informatica. È usuale utilizzare tecniche derivate dall'[[intelligenza artificiale]], come ad esempio il [[data mining]], per cercare di estrarre relazioni o più in generale informazioni presenti nelle banche dati, ma non immediatamente visibili.
È usuale utilizzare tecniche derivate dall'[[intelligenza artificiale]], come ad esempio il [[data mining]], per cercare di estrarre relazioni o più in generale informazioni presenti nelle banche dati ma non immediatamente visibili.
 
=== Struttura oe modello logico ===
[[File:Hierarchisches_Datenbankmodell.svg|thumb|Modello gerarchico di database]]
Le basi di dati possono avere varie strutture, di solito, in ordine cronologico:
Le [[informazione|informazioni]] contenute in una banca dati sono strutturate e collegate tra loro secondo un particolare modello logico scelto dal progettista, per esempio [[Modello relazionale|relazionale]], [[Modello gerarchico|gerarchico]], [[Modello reticolare|reticolare]] o [[Modello a oggetti|a oggetti]]. Gli utenti si interfacciano con le banche dati attraverso i cosiddetti [[linguaggio di interrogazione|linguaggi di interrogazione]] ([[query]] di ricerca o interrogazione, inserimento, cancellazione, aggiornamento ecc.) e grazie a particolari applicazioni [[software]] dedicati (DBMS).
 
Di solito le banche dati possono avere varie strutture, in ordine cronologico di comparsa e diffusione:
# ''gerarchica'' (rappresentabile tramite un albero – [[anni 1960|anni sessanta]]),
# ''reticolare'' (rappresentabile tramite un grafo – [[anni 1960|anni sessanta]]),
# ''[[Modello relazionale|relazionale]]'' (attualmente il più diffuso, rappresentabile mediante tabelle e relazioni tra esse – [[anni 1970|anni settanta]]),
# ''ad oggetti'' (estensione alle basi di dati del paradigma "Object Oriented", tipico della programmazione a oggetti – [[anni 1980|anni ottanta]]),
# ''semantica'' (rappresentabile con un grafo relazionale – inizio [[anni 2000|anni duemila]]).
 
# [[Modello gerarchico|gerarchico]] (anni sessanta) rappresentabile tramite un [[albero (informatica)|albero]], ovvero con strutture simili ai [[file system]] gerarchici,
Il formato [[XML]], oltre che per scambi di dati su web, si sta diffondendo per la definizione di vere e proprie basi di dati. XML ha una struttura gerarchica, pare quindi un "ritorno alle origini" dei modelli di dati.
# [[Modello reticolare|reticolare]] (anni sessanta) rappresentabile tramite un [[grafo]],
# [[Modello relazionale|relazionale]] ([[anni 1970|anni settanta]]) attualmente il più diffuso, rappresentabile mediante tabelle e relazioni tra esse,
# [[Modello a oggetti|a oggetti]] ([[anni 1980|anni ottanta]]) estensione alle basi di dati del paradigma "Object Oriented", tipico della programmazione a oggetti,
# [[Database orientato al documento|Document-oriented]] (NoSQL),
# [[Key-Value Store]] (NoSQL),
# [[Database a grafo|Graph-based]] (NoSQL),
# [[Colonnari]] (NoSQL),
# semantica (inizio [[anni 2000|anni duemila]]) rappresentabile con un grafo relazionale.
[[File:Netzwerkdatenbankmodell.svg|thumb|Modello reticolare di database]]
 
Il formato [[XML]], oltre che per scambi di dati in rete, si sta diffondendo per la definizione di vere e proprie basi di dati. XML ha una struttura gerarchica, pare quindi un "ritorno alle origini" dei modelli di dati.
Un requisito importante di una buona base dati consiste nel non duplicare inutilmente le informazioni in essa contenute: questo è reso possibile dai gestori di [[RDBMS|database relazionali]] (teorizzati da [[Edgar F. Codd]]), che consentono di salvare i dati in tabelle che possono essere collegate.
 
Un requisito importante di una buona banca dati consiste nel non duplicare inutilmente le informazioni in essa contenute: questo è reso possibile dai gestori di [[RDBMS|banche dati relazionali]], teorizzati da [[Edgar F. Codd]], che consentono di salvare i dati in tabelle che possono essere collegate.
La funzionalità di un database dipende in modo essenziale dalla sua progettazione: la corretta individuazione degli scopi del database e quindi delle tabelle, da definire attraverso i loro campi e le relazioni che le legano, permette poi una estrazione dei dati più veloce e, in generale, una gestione più efficiente.
 
La funzionalità di una banca dati dipende in modo essenziale dalla sua [[progettazione]]: la corretta individuazione degli scopi della banca dati stessa e quindi delle tabelle, da definire attraverso i loro campi e le relazioni che le legano, permette poi una estrazione dei dati più veloce e in generale una gestione più efficiente.
=== Linguaggi per basi di dati ===
 
Nell'ambito dell'utilizzo/amministrazione del database, una qualunque operazione sulla base di dati da parte dell'utente/amministratore su DBMS è ottenibile tramite un opportuno linguaggio attraverso un [[DBMS manager]] ad [[interfaccia grafica]] o ad [[interfaccia a riga di comando]]. In generale è possibile distinguere più linguaggi per basi di dati (ciascuno con lessico e [[sintassi (informatica)|sintassi]] che definiscono tutte le [[istruzione (informatica)|istruzioni]] possibili) a seconda del loro utilizzo o finalità a partire dalla creazione/progettazione, gestione, ristrutturazione, sicurezza, fino all'interrogazione del database stesso:
=== Proprietà ACID ===
{{vedi anche|Transazione (basi di dati)|ACID|Trigger (basi di dati)}}
Una qualunque modifica allo stato del database tramite operazioni varie è detta [[Transazione (basi di dati)|transazione]], la quale deve rispettare le cosiddette regole o proprietà [[ACID]]. Le operazioni più tipiche in un DB sono quelle riassunte dall'acronimo [[CRUD]].
 
=== Efficienza e sicurezza ===
{{vedi anche|Protezione dai guasti (basi di dati)|Attacco ai database}}
Sicurezza significa impedire che la base dati venga danneggiata da interventi accidentali o non autorizzati, per esempio un [[attacco ai database]], e mantenerne l'integrità ovvero garantire che le operazioni effettuate sulla base di dati da utenti autorizzati non provochino una perdita consistente di dati, garantendone al contempo l'[[affidabilità (basi di dati)|affidabilità]]. La protezione da accessi non autorizzati è un tema importante nella gestione delle basi di dati che si rivelano vulnerabili nei seguenti punti:
 
* [[Sicurezza informatica|Sicurezza dei server]]
* Connessioni tra database
* Controllo sugli accessi al database
* [[Data warehouse]]
* [[Data mining]]
 
== Classificazione ==
 
=== Secondo il modello dei dati ===
 
==== Base di dati navigazionale ====
{{vedi anche|Modello gerarchico|Modello reticolare}}
 
Le basi di dati navigazionali sono orientate alla navigazione manuale in un insieme di dati disposti sotto forma di rete o [[albero (informatica)|albero]]. Alla prima apertura del programma questo si trovava sul primo dato disponibile contenente, tra le altre cose, un [[Puntatore (programmazione)|puntatore]] ai dati successivi. Per trovare un dato il programma attraversava la serie di puntatori fino a trovare il dato corretto.
 
Questi modelli non brillano particolarmente in prestazioni.
Delle semplici ''[[query]]'' come "Trova tutte le persone nate in Svezia" richiedono l'attraversamento dell'intero set di dati. Non è prevista alcuna funzione di ricerca; oggi questo potrebbe sembrare una limitazione, ma all'epoca, essendo i dati archiviati su [[nastro magnetico]], operazioni come quelle evidenziate sopra peggioravano ulteriormente il tempo di ricerca.
 
Alcuni esempi di DBMS basati su modelli navigazionali sono: IDS, IDMS, CINCOM, [[TOTAL]] e [[Information Management System|IMS]].
 
==== Base di dati relazionale ====
{{vedi anche|Modello relazionale}}
 
[[File:Relational_Model.jpg|thumb|In una base di dati relazionale i dati sono organizzati in relazioni, ovvero [[tupla|tuple]] di valori correlati che rappresentano un'entità univoca. Tuple diverse possono essere associate individuando valori chiave in comune.]]
 
Uno degli aspetti interessanti introdotti nelle banche dati relazionali sta nel collegamento delle tabelle: nel modello relazionale, per ogni [[record (database)|record]] viene definita una [[Chiave (basi di dati)|chiave]], ovvero un identificatore univoco della tupla. Nella ricostruzione delle relazioni, l'elemento di riferimento, che distingue una riga da un'altra è proprio questa chiave e viene richiamata nella definizione della relazione. La chiave può essere uno dei dati stessi che vengono memorizzati (ad esempio, per la tabella utenti, il "Codice Fiscale" della persona), una loro combinazione (chiave composta), o ancora un campo che viene aggiunto specificatamente per questo scopo. In ogni caso, la chiave primaria deve essere presente in ogni tupla e mai ripetuta più di una volta in ogni relazione.
 
==== Base di dati multidimensionali ====
Le banche dati multidimensionali sono un paradigma definito ancora una volta da Codd per sopperire alle scarse performance offerte dalle banche dati relazionali nel caso di utilizzo delle banche dati stesse per processi di analisi ([[on line analitical process]], OLAP). Tali sistemi consentono di effettuare analisi su enormi quantità di dati con efficienza, cosa non possibile su banche dati relazionali più adatte a gestire transazioni ([[on line transaction process]], OLTP).
 
Da fine anni '90 pressoché ogni banca dati relazionale commerciale ha al suo interno un motore multidimensionale per effettuare analisi.
 
==== Base di dati NoSQL ====
{{vedi anche|NoSQL}}
''NoSQL'' è un movimento che promuove sistemi [[software]] dove la [[persistenza (informatica)|persistenza]] dei dati è in generale caratterizzata dal fatto di non utilizzare il [[modello relazionale]], di solito usato dalle basi di dati tradizionali ([[RDBMS]]). L'espressione "NoSQL" fa riferimento al linguaggio [[SQL]], che è il più comune linguaggio di interrogazione dei dati nelle banche dati relazionali, qui preso a simbolo dell'intero paradigma relazionale.
 
===== Base di dati orientata al documento =====
{{vedi anche|Base di dati orientata al documento}}
Una Base di dati orientata al documento è un programma per applicazioni orientate al documento. Questi sistemi potrebbero essere implementati come strato sopra un database relazionale o a oggetti.
 
Le basi di dati orientate al documento non memorizzano i dati in tabelle con campi uniformi per ogni record come nei database relazionali, ma ogni record è memorizzato come un documento che possiede determinate caratteristiche. Qualsiasi numero di campi con qualsiasi lunghezza può essere aggiunto al documento. I campi possono anche contenere pezzi multipli di dati.
 
===== Base di dati a grafo =====
{{vedi anche|Base di dati a grafo}}
[[File:GraphDatabase_PropertyGraph.svg|thumb|[[Base di dati a grafo]]]]
Una base di dati a grafo usa nodi e archi per rappresentare e archiviare l'informazione.
La rappresentazione dei dati mediante [[grafo|grafi]] offre un'alternativa al [[modello relazionale]] che fa uso di tabelle, alle [[Base di dati orientata al documento|basi di dati orientate al documento]] (che usano documenti), o altri, come i sistemi ad [[archivio strutturato|archivi strutturati]] (structured storage) basati su colonne o su cesti non interpretati di dati.
 
I database a grafo sono spesso più veloci di quelli relazionali nell'associazione di set di dati, e mappano in maniera più diretta le strutture di applicazioni orientate agli oggetti.
Scalano più facilmente a grandi quantità di dati e non richiedono le tipiche e onerose operazioni di unione ([[Join (SQL)|join]]).
Dipendono meno da un rigido schema [[entità-relazione]] e sono molto più adeguati per gestire dati mutevoli con schemi evolutivi.
Al contrario, i database relazionali sono tipicamente più veloci nell'eseguire le stesse operazioni su un grande numero di dati.
 
===== Base di dati a oggetti =====
{{vedi anche|Base di dati a oggetti}}
 
Evoluzione del precedente [[#Base di dati multidimensionale|modello multidimensionale]], questa tipologia di sistemi consente di memorizzare direttamente "oggetti" affini a quelli utilizzati nella [[programmazione a oggetti]].
Questo permette di aggirare il problema dell{{'}}''[[Object-relational impedance mismatch]]''.
 
Questo può avvenire grazie al particolare concetto di proprietà delle banche dati multidimensionali. Nella programmazione a oggetti, ognuno di questi "oggetti" tipicamente ne conterrà altri. Ad esempio, l'oggetto contenente il Signor Rossi, conterrà un riferimento all'oggetto "Indirizzo". Contenendo il supporto per molti linguaggi di programmazione a oggetti, le banche dati che sfruttano la medesima tecnologia stanno avendo un periodo di forte sviluppo di questi tempi.
 
==== Base di dati spaziale ====
{{Vedi anche|Base di dati spaziale}}
 
Una base di dati spaziale è una base di dati ottimizzata per archiviare e interrogare dati correlati a oggetti nello spazio, tra cui punti, linee e poligoni. Nelle basi di dati spaziali sono integrate quindi delle funzionalità aggiuntive per processare tipi di dati spaziali. L'[[Open Geospatial Consortium]] ha creato le specifiche ''Simple Features'' che stabiliscono degli standard per l'aggiunta di funzionalità spaziali alle banche dati.
 
==== Base di dati multimediale ====
{{vedi anche|Base di dati multimediale}}
 
Una base di dati multimediale è una base di dati che raccoglie oggetti di tipo testo, immagine, oggetti 3D, audio, video e una combinazione di questi e fornisce strumenti per la loro memorizzazione, accesso, ricerca e controllo. Attualmente il DBMS Oracle fornisce funzioni tipiche delle basi di dati multimediali.
 
=== Secondo la tipologia di servizio ===
 
==== Base di dati in cloud ====
{{vedi anche|Cloud database}}
 
Quella dei ''database'' in ''cloud'' è una tipologia di basi di dati che viene ospitata su una piattaforma di ''[[cloud computing]]''. Nelle versioni più evolute la maggior parte del sistema database è gestito dalla piattaforma cloud, lasciando al proprietario solo compiti amministrativi di alto livello. Si parla in questo caso di ''Database-as-a-Service'' (DBaaS).
 
=== Secondo la modalità di accesso ai dati ===
 
==== Base di dati parallela ====
{{vedi anche|Database parallelo}}
Un database parallelo è un tipo di database in cui le prestazioni vengono ottimizzate tramite la parallelizzazione di varie funzionalità, ad esempio il caricamento dei dati, la costruzione degli indici e la gestione delle interrogazioni. Nell'esecuzione parallela, molte operazioni sono eseguite contemporaneamente, al contrario dell'esecuzione seriale, dove le diverse fasi di elaborazione sono sequenziali.
 
==== Base di dati distribuita ====
{{vedi anche|Database distribuito}}
In informatica un database distribuito è un database che si trova sotto il controllo di un database management system (DBMS) nel quale gli archivi di dati non sono memorizzati sullo stesso computer bensì su più elaboratori o nodi. In altri termini il database in senso fisico può essere dislocato in più computer situati nello stesso luogo, oppure distribuito in una rete di computer connessi tra loro sotto forma appunto di sistema distribuito.
 
== Progettazione ==
{{vedi anche|Progettazione di basi di dati}}
[[File:ER_Diagram_MMORPG.svg|thumb|Un [[Modello ER|diagramma ER]]. Tipicamente utilizzato durante le prime fasi di progettazione di una base di dati, per rappresentarla in modo astratto.]]
 
La progettazione di basi di dati è il processo di formulazione di un modello dettagliato del database. Questo modello contiene tutte le scelte progettuali a livello logico e fisico e i parametri fisici di memorizzazione necessari per la generazione del [[Data Definition Language|data definition language]] (DDL) che può essere usato per l'implementazione del database. Un modello dei dati completamente specificato contiene i dettagli specifici per ogni singola entità.
 
== Gestione ==
{{vedi anche|Database management system}}
{{...|informatica}}
 
=== Linguaggi di interrogazione ===
Nell'ambito dell'utilizzo/amministrazione della base di dati, una qualunque operazione sulla base di dati da parte dell'utente/amministratore su DBMS è ottenibile tramite un opportuno linguaggio attraverso un [[DBMS manager]] a [[interfaccia grafica]] o a [[interfaccia a riga di comando]]. In generale è possibile distinguere più linguaggi per basi di dati, ciascuno con lessico e [[sintassi (informatica)|sintassi]] che definiscono tutte le [[istruzione (informatica)|istruzioni]] possibili, a seconda del loro utilizzo o finalità a partire dalla creazione/progettazione, gestione, ristrutturazione, sicurezza, fino all'interrogazione della base di dati stessa:
 
* [[Data Definition Language]] (DDL) - consente di definire la struttura o organizzazione logica della base di dati ([[schema di database]]) e le autorizzazioni per l'accesso.
* [[DMCL|Device Media Control Language]] (DMCL) - permette di controllare i supporti ([[memoria di massa]]) dove vengono memorizzati i dati.
* [[Data Manipulation Language]] (DML) - permette di inserire, modificare, cancellare i dati ([[transazione (basi di dati)|transazione]]).
* [[Data Control Language]] (DCL) - permette di gestire gli utenti e i permessi.
* [[QueryDMCL|Device languageMedia Control Language]] (QLDMCL) - permette di interrogarecontrollare ili database,supporti cioè([[memoria di leggeremassa]]) dove vengono memorizzati i dati.
* [[Query language]] (QL) - permette di interrogare il database, cioè estrarre e leggere i dati.
 
La sintassi di questi linguaggi varia a seconda del particolare DMBS,DBMS mantenendoe i vari linguaggi mantengono tra loro un'uniformità concettuale.
 
Inoltre è possibile suddividere i linguaggi come:
* Linguaggi testuali interattivi, come l'[[SQL]], che rappresenta attualmente il linguaggio più utilizzato e di cui sono stati pubblicati diversi [[standard (informatica)|standard]], che rappresenta attualmente il linguaggio più utilizzato.
* Linguaggi testuali interattivi immersi in [[linguaggio di programmazione|linguaggi di programmazione]] comuni, quali [[C (linguaggio)|C]], [[BASIC|Basic]] ecc.
* Linguaggi testuali interattivi immersi in linguaggi di programmazione proprietari.
* Linguaggi grafici e ''[[user-friendly]]'', come [[QBE]] (Query By Example), che possono essere utilizzati anche dai meno esperti.
 
=== ServerAspetti digiuridici databasee legali ===
{{U|verso=a|Diritto d'autore#Banche dati|informatica|maggio 2024}}
Un [[Server]] di database è la parte del [[DBMS]] (e, per estensione, il [[server]] su cui il programma opera) che si occupa di fornire i servizi di utilizzo del database ad altri [[programma (informatica)|programmi]] e ad altri [[computer]] secondo la modalità [[client/server]]. Il server memorizza i dati, riceve le richieste dei [[client]] ed elabora le [[output|risposte]] appropriate.
{{L|diritto|gennaio 2024|arg2=informatica}}
 
=== Italia ===
Tra i più diffusi DBMS [[open source]] troviamo:
In Italia l'art 64 quinquies della [[legge 22 aprile 1941, n. 633]] sul diritto d'autore prevede che:{{Citazione|L'autore di una banca di dati ha il diritto esclusivo di eseguire o autorizzare:}}{{Citazione|a) la riproduzione permanente o temporanea, totale o parziale, con qualsiasi mezzo e in qualsiasi forma;}}{{Citazione|b) la traduzione, l'adattamento, una diversa disposizione e ogni altra modifica;}}{{Citazione|c) qualsiasi forma di distribuzione al pubblico dell'originale o di copie della banca di dati; la prima vendita di una copia nel territorio dell'Unione europea da parte del titolare del diritto o con il suo consenso esaurisce il diritto di controllare, all'interno dell'Unione stessa, le vendite successive della copia;}}{{Citazione|d) qualsiasi presentazione, dimostrazione o comunicazione in pubblico, ivi compresa la trasmissione effettuata con qualsiasi mezzo e in qualsiasi forma;}}{{Citazione|e) qualsiasi riproduzione, distribuzione, comunicazione, presentazione o dimostrazione in pubblico dei risultati delle operazioni di cui alla lettera b).}}<ref>{{Cita web|url=http://www.altalex.com/documents/codici-altalex/2014/06/26/legge-sul-diritto-d-autore#titolo1|titolo=Legge sul diritto d'autore {{!}} Altalex|sito=Altalex|accesso=18 gennaio 2017|urlarchivio=https://web.archive.org/web/20190605100158/https://www.altalex.com/documents/codici-altalex/2014/06/26/legge-sul-diritto-d-autore#titolo1|dataarchivio=5 giugno 2019|urlmorto=sì}}</ref>
* [[MySQL]]
* [[Firebird SQL]]
* [[PostgreSQL]]
 
L'autore di una banca di dati, che ha scelto e organizzato creativamente il materiale all'interno della raccolta, è quindi titolare delle facoltà esclusive di natura patrimoniale e morale riconosciute a tutti gli autori di opere dell'ingegno secondo l'articolo 64-quinquies e seg. della [[legge 633/1941]]. I diritti esclusivi di riproduzione, traduzione, adattamento, distribuzione, presentazione e dimostrazione sono detti diritti patrimoniali, cioè hanno un valore economicamente valutabile. In quanto patrimoniali i sopracitati diritti sono trasferibili.
I più diffusi sistemi commerciali sono:
* [[Oracle]]
* [[IBM]] [[DB2]]
* [[Microsoft SQL Server]]
* [[Adaptive Server Enterprise|Sybase]]
* [[Microsoft Access]]
 
L'autore può quindi effettuare o autorizzare: la riproduzione permanente o temporanea, totale o parziale, la traduzione, le modifiche, gli adattamenti e le diverse disposizioni del materiale, la distribuzione, la presentazione in pubblico e l'utilizzazione economica.
I database server sono complessi sistemi software concepiti in un linguaggio binario, oltre che per memorizzare i dati, anche per fornire un accesso rapido ed efficace a una pluralità di utenti contemporaneamente e garantire protezione sia dai [[guasto|guasti]] che dagli accessi indebiti (sicurezza o protezione del database)
 
C'è invece la possibilità di una libera utilizzazione quando l'accesso e la consultazione sono svolte per finalità didattiche o di ricerca scientifica, quando l'uso dei dati persegue fini di sicurezza pubblica e quando i dati sono utilizzati per una procedura amministrativa o giurisdizionale. La durata del diritto d'autore è di 70 anni dalla morte dell'autore.
=== Sicurezza dei database ===
{{vedi anche|Protezione del database}}
La protezione da accessi non autorizzati è un tema importante nella gestione dei database, che si rivelano vulnerabili nei seguenti punti:
 
In qualunque caso le banche dati sono tutelate dal diritto d’autore indipendentemente dalla tutela eventualmente accordata alle opere o ai dati da cui esse sono composte, con la precisazione che la tutela della banca dati non si estende alle opere o dati in questione. In sostanza la tutela riguarda la struttura della banca dati, in pratica la sua forma espressiva.
* [[Sicurezza informatica|Sicurezza dei server]]
* Connessioni tra database
* Controllo sugli accessi al database.
* [[Data warehouse]]
* [[Data mining]]
 
Nel caso in cui la banca di dati sia originale, cioè con dati organizzati secondo criteri originali e non per esempio in ordine alfabetico o cronologico, l'autore gode dei diritti morali e di sfruttamento economico della banca dati stessa. Invece nel caso in cui la banca dati non sia originale la tutela dei diritti non è per l'autore, ma per il costruttore ovvero colui che effettua investimenti per la costituzione della banca dati. Al costitutore della banca di dati sarà riconosciuta, sul solo territorio dell'[[Unione europea]], la titolarità di un diritto [[sui generis]] diverso dal diritto d'autore e dai diritti connessi, volto a tutelare il lavoro svolto e gli investimenti effettuati. Infatti il costitutore può vietare le operazioni di estrazione e reimpiego della totalità o di una parte della banca dati. La durata del diritto del costitutore è di 15 anni, rinnovabile in caso di modifiche o integrazioni sostanziali apportate alla raccolta. Il conteggio dei 15 anni comincia dal 1º gennaio dell'anno successivo alla data del completamento della banca dati. Nel caso in cui il database sia accessibile via internet i 15 anni cominciano dal 1º gennaio successivo alla messa a disposizione della banca di dati stessa.
== Web database ==
{{F|basi di dati|marzo 2010}}
I ''web database'' sono un particolare tipo di [[Web service|servizi web]] che offrono la possibilità di creare database direttamente sul [[Web]]. Questi servizi offrono normalmente tutte le caratteristiche base di un normale database per costruire tabelle strutturate di dati di ogni genere con campi di tipo testo, numeri, data e ora e altri.
 
=== Unione europea ===
Il loro servizio non è solo quello di [[repository]] o contenitore di dati, ma anche quello di creare un'[[interfaccia grafica]] [[Usabilità|usabile]] per la gestione degli stessi presentandosi come vere e proprie [[applicazione web|applicazioni web]].
Il diritto alla protezione è stato riconosciuto in nell'[[Unione europea]] grazie all’introduzione della Direttiva 96/9/CE presentata dall’[[Unione europea]], in cui si parla del suddetto diritto nel capitolo III e più precisamente negli articoli che vanno dal 7 fino all'11.<ref>{{Cita web|url=https://eur-lex.europa.eu/legal-content/IT/TXT/HTML/?uri=CELEX:31996L0009&from=EN|titolo=Direttiva 96/9/CE del Parlamento europeo e del Consiglio}}</ref>
La condivisione svolge un ruolo importante proprio perché i dati sono visibili su [[Internet]] e quindi da altre persone che, con le dovute autorizzazioni, possono lavorare sui dati.
 
Tramite questo diritto, gli Stati membri conferiscono al costitutore di una banca di dati la possibilità di vietare operazioni di estrazione e/o reimpiego della totalità o di una parte sostanziale del contenuto della stessa, valutata in termini qualitativi o quantitativi, qualora il conseguimento, la verifica e la presentazione di tale contenuto attestino un investimento rilevante.
== Diritto d'autore ==
La [[Direttiva Europea|direttiva dell'Unione Europea]] n. 96/9/CE ha introdotto un diritto (qualificato ''sui generis'') a tutela dell'estensore di una ''banca dati''. In Italia tale normativa è stata disciplinata dal TitoloII-bis LdA: ''Disposizioni sui diritti del costitutore di una banca di dati. La tutela riguarda quelli che compiono una selezione o collocazione del materiale raccolto<ref>Confronta Jarach-Pojaghi ''Manuale del diritto d'autore Mursia ISBN 978-88-425-3817-2</ref>
 
Gli Stati membri possono inoltre stabilire che l'utente legittimo di una banca di dati messa in qualsiasi modo a disposizione del pubblico possa, senza autorizzazione del costitutore della stessa, estrarre e/o reimpiegare una parte sostanziale del contenuto di tale banca:
== Database management system (DBMS) ==
 
{{div col|cols=3}}
a) qualora si tratti di un'estrazione per fini privati del contenuto di una banca di dati non elettronica;
* [[4th Dimension]]
 
* [[Adabas]]
b) qualora si tratti di un'estrazione per finalità didattiche o di ricerca scientifica, purché l'utente legittimo ne citi la fonte e in quanto ciò sia giustificato dagli scopi non commerciali perseguiti;
* [[Addamark]]
 
* [[AskSam]]
c) qualora si tratti di estrazione e/o reimpiego per fini di sicurezza pubblica o per una procedura amministrativa o giurisdizionale.
* [[Berkeley DB]]
 
* [[Caché]]
La tutela sui generis è quindi una protezione dell’insieme delle informazioni contenute all’interno di una banca dati, considerando lo sforzo impiegato per la sua realizzazione.
* [[Conzept16]]
 
* [[c-tree Plus]]
Per tali ragioni la tutela sui generis trova il suo fondamento giuridico nel [[principio di territorialità]], in quanto solo le banche dati create da un cittadino di uno Stato membro dell’Unione europea ne beneficiano.
* [[c-store]]
 
* [[Dataphor]] un [[RDBMS]] "''veramente''-relazionale" che rispetta tutte le [[12 regole di Codd|regole di Codd]].
Il requisito fondamentale richiesto per la concessione della tutela sui generis è un ingente investimento di risorse umane ed economiche, in modo tale da poter differenziare la raccolta con una semplice copia di informazioni, che non richiede un impiego tanto grande. L'investimento che viene preso in considerazione riguarda le attività di raccolta di dati, la verifica delle informazioni e la presentazione dell’insieme dei materiali.
* [[DB1]]
 
* [[DB2]]
Analizzando il [[diritto d'autore]] e il diritto sui generis, in questa prospettiva, è facile capire le differenze. Il primo si limita a proteggere la forma, quindi l’architettura e la sequenza in cui sono disposti i dati, frutto di una elaborazione creativa; il secondo si applica al materiale raccolto, a prescindere dal modo in cui viene organizzato.
* [[DB4Object]]
 
* [[DBMaker]]
== Note ==
* [[dBase]]
<references/>
* [[Apache Derby|Derby]]
 
* [[Drizzle]]
== Bibliografia ==
* [[FileMaker]]
* {{cita libro|autore= Paolo Atzeni|autore2= Stefano Ceri|autore3= Piero Fraternali|autore4= Stefano Paraboschi|autore5= Riccardo Torlone|titolo= Basi di dati|editore= McGraw-Hill|anno= 2018|edizione= 5|città= Milano|ISBN= 978-88-386-9445-5|cid= Atzeni 2018}}
* [[Pagine Elettroniche]]
*{{Cita libro|titolo=Data base – Concetti e disegno|url=https://archive.org/details/databaseconcettiedisegno|autore=Roberto Doretti|editore=Gruppo Editoriale Jackson|anno=1985|ISBN=88-7056-174-7}}
* [[Firebird SQL]]
*{{cita libro|ISBN=978-0133970777|autore1=Ramez Elmasri|autore2=Shamkant B. Navathe|titolo=Fundamentals of Database Systems|edizione=4|editore=Addison Wesley|anno=2003|lingua=en}}
* [[FoxBase]]
*{{cita libro|ISBN=9780136079385|autore1=M. Tamer Özsu|autore2=Patrick Valduriez|titolo=Principles of Distributed Database Systems|editore=Prentice Hall|anno=1999|lingua=en}}
* [[Gupta SQLBase]]
*{{cita pubblicazione|autore=Giovanni Guglielmetti|titolo=La tutela delle banche dati con diritto sui generis nella direttiva 96/9/CE|pubblicazione=Contratto e impresa / Europa|anno=1997|pp=177 e segg}}
* [[HSQLDB]]
*{{cita libro|ISBN=9788814064722|autore=Paola Ada Emauela Frassi|titolo=Creazioni utili e diritto d'autore. Programmi per elaboratore e raccolte di dati|editore=Giuffrè|anno=1997}}
* [[IDMS]]
*{{cita libro|ISBN=9788814075605|autore1=Laura Chimienti|autore2=Niccolò Machiavelli|titolo=Banche dati e diritto d'autore|editore=Giuffrè|anno=1999}}
* [[Information Management System]]
* {{cita pubblicazione|autore = Edgar F. Codd | wkautore=Edgar F. Codd|titolo = A Relational Model of Data for Large Shared Data Banks|rivista = Communications of ACM|volume = 13|numero = 6|data = 1970-06-01|editore = [[Association for Computing Machinery]]|lingua = en|doi= 10.1145/362384.362685|cid = Codd 1970}}
* [[INGRES]]
* [[Informix]]
* [[InterBase]]
* [[Kdb]]
* [[Lotus Approach]]
* [[Lucid db]]
* [[Microsoft Access]]
* [[Microsoft SQL Server]]
* [[MariaDB]]
* [[Monet Db]]
* [[mSQL]]
* [[MySQL]]
* [[MySQL MaxDb]]
* [[Oracle]]
* [[Orient ODBMS]]
* [[PicoSQL]]
* [[PostgreSQL]]
* [[Progress]]
* [[Sadas]]
* [[SapDb]]
* [[SQLite]]
* [[SQL Anywhere Studio]]
* [[Sybase SQL Server]]
* [[TimeSten]]
* [[Vertica]]
{{div col end}}
 
== Voci correlate ==
{{div col|cols=3}}
* [[ACID]]
* [[Affidabilità (basi di dati)]]
* [[Algebra relazionale]]
* [[Attacco ai database]]
* [[Base di conoscenza]]
* [[BaseBig di dati a grafodata]]
* [[Blockchain]]
* [[Base di dati multimediale]]
* [[CacheData integration]]
* [[CampoData (informatica)warehouse]]
* [[Chiave (basi di dati)]]
* [[Database distribuiti]]
* [[DBMS]]
* [[Descrittore (informazione)]]
* [[Direttiva relativa alla tutela giuridica delle banche di dati]]
* [[DomainLinguaggio Namedi Systeminterrogazione]]
* [[Open Database Connectivity]]
* [[Dump]]
* [[Modello reticolare]]
* [[Modello gerarchico]]
* [[Modello a oggetti]]
* [[Normalizzazione del database]]
* [[Protezione del database]]
* [[Query]]
* [[QueryRecord language(database)]]
* [[Record (informatica)]]
* [[Schema di database]]
* [[Sistema informativo aziendale]]
* [[Schema evolution]]
* [[SistemaStructured informativoQuery Language]]
* [[SQL]]
* [[JDBC]]
* [[ODBC]]
* [[Transazione (basi di dati)]]
* [[Datawarehouse]]
* [[Business intelligence]]
{{div col end}}
 
== Note ==
<references/>
 
== Bibliografia ==
* Atzeni, Ceri, Paraboschi, Torlone – ''Basi Di Dati (Modelli e Linguaggi di Interrogazione)'' - McGraw Hill, 2003
* Atzeni, Ceri, Fraternali, Paraboschi, Torlone – ''Basi Di Dati (Architetture e Linee Di Evoluzione)'' - McGraw Hill, 2003
* Ramez Elmasri, Shamkant B. Navathe – ''Fundamentals of Database Systems'', Fourth Edition – Addison Wesley, 2003
* Tamer-Ozsu, P. Valduriez – ''Principles of Distributed Database Systems ''- Prentice Hall, 1999
* Giovanni Guglielmetti, ''La tutela delle banche dati con diritto sui generis nella direttiva 96/9/CE'', in Contratto e impresa / Europa, 1997, pag. 177 e segg.;
 
== Altri progetti ==
{{interprogetto|preposizione=sul|etichetta=database|wikt=database|v_oggetto=la materia|v_preposizione= |v_etichetta=Basi di dati|v=Materia: Basi di dati 1}}
{{interprogetto|commons=Category:Database}}
 
== Collegamenti esterni ==
* {{Collegamenti esterni}}
* [http://www.basebear.com BaseBear] Un esempio di web database
* {{FOLDOC|database|database}}
 
{{Archivistica}}
{{Portale|informatica|web}}
{{Controllo di autorità}}
{{Portale|informatica|internet|scienza e tecnica}}
 
[[Categoria:Basi di dati| ]]