Nei database le Colonne Virtuali sono campi di una tabella il cui valore viene calcolato in base al valore di altre colonne, o di altre espressioni deterministiche. Non fanno parte degli standard SQL e sono implementate solo da alcuni DBMS, come MariaDB, SQL Server e Oracle.

Le Colonne Virtuali naturalmente non sono compatibili con la normalizzazione dei database, perché creano una ridondanza.

Implementazione modifica

Le Colonne Virtuali, nelle varie implementazioni, possono essere di due tipi:

  • Virtual
  • Persistent

I valori delle colonne Virtual vengono calcolati "al volo" quando è necessario, per esempio quando devono essere restituiti da una query di tipo SELECT. I valori nelle colonne Persistent invece vengono calcolati al momento in cui la riga viene scritta su disco, e scritti insieme a tutti gli altri valori. A seconda dei casi si può preferire un tipo o l'altro: le Virtual non occupano spazio su disco ma richiedono l'elaborazione di un'espressione ad ogni query che le coinvolge; le Persistent invece non richiedono alcun lavoro aggiunto da parte della CPU, ma occupano spazio su disco. Ad ogni modo non è sempre possibile scegliere, perché alcuni DBMS supportano solo un tipo di colonne.

Le Colonne Virtuali in MariaDB modifica

MariaDB è un fork di MySQL; nella versione 5.2 sono state aggiunte (fra le altre funzionalità) le Colonne Virtuali, migliorate in[manca un pezzo]. Al momento, quindi, esse non sono presenti in MySQL.

Le espressioni usate per calcolare i valori sono soggette alle seguenti limitazioni:

  • Devono essere deterministiche.
  • Non devono essere valori costanti.
  • Non possono basarsi su UDF o Stored procedure (nemmeno se queste sono deterministiche).
  • Non possono basarsi su altre Colonne Virtuali.

Possono essere indicizzate e possono essere parte di Chiavi Esterne, tuttavia anche su questo aspetto esistono delle piccole limitazioni.

Sintassi modifica

Per creare una Colonna Virtuale, si utilizza questa sintassi all'interno di un comando CREATE TABLE o ALTER TABLE:

<tipo>  [GENERATED ALWAYS]  AS   ( <espressione> )  [VIRTUAL | PERSISTENT]  [UNIQUE] [UNIQUE KEY] [COMMENT <testo>]
  • tipo è il tipo di dato della Colonna Virtuale.
  • espressione è l'espressione SQL usata per calcolare i valori.
  • testo è il commento da associare alla colonna (opzionale).

Le Colonne Virtuali in Oracle modifica

Le Colonne Virtuali sono state aggiunte in Oracle a partire dalla versione 11g, release 1.

L'unico tipo di Colonne Virtuali supportate da Oracle sono le Virtual, pertanto non esiste la possibilità di scrivere tali valori su disco. Per ovviare a questa mancanza, è possibile utilizzare le viste materializzate.

Sintassi modifica

Per creare una Colonna Virtuale, si utilizza la seguente sintassi all'interno di un comando CREATE TABLE o ALTER TABLE:

nome_colonna [tipo] [GENERATED ALWAYS] AS (espressione) [VIRTUAL]

SQL Server modifica

SQL Server supporta le Colonne Virtuali, ma le chiama Computed Column (colonne calcolate).

L'unico tipo supportato in SQL Server è Persisted, che equivale di fatto a Persistent.

Strumenti di business intelligence modifica

Negli strumenti di business intelligence come Tableau, Microsoft Power BI o il tabular model di Microsoft Analysis Service le colonne virtuali chiamate colonne calcolate sono essenziali per produrre dati e grafici significativi.

Alternative alle Colonne Virtuali modifica

Nei DBMS che non supportano le Colonne Virtuali, è possibile ottenere funzionalità equivalenti o simili utilizzando:

  • le viste, per sostituire le colonne di tipo Virtual;
  • le viste materializzate, oppure trigger che riempiono una tabella apposita, per sostituire le colonne Persistent.

Entrambe le soluzioni sono più complesse e meno semplici da mantenere, pertanto si tende a preferire le Colonne Virtuali se sono supportate.

Viste modifica

Le viste possono contenere colonne lette direttamente dalle colonne di una tabella e altre colonne calcolate in base a un'espressione SQL. Le viste possono quindi sostituire le colonne di tipo Virtual. Alcuni DBMS supportano le viste materializzate, che possono sostituire le colonne di tipo Persistent, al costo però di duplicare tutti i dati di una tabella, e quindi anche lo spazio occupato sul disco. Inoltre, non esiste una soluzione per simulare sia colonne Persistent sia Virtual all'interno di un'unica vista.

Trigger modifica

I Trigger possono scrivere dati in una tabella subito dopo un'istruzione UPDATE o INSERT; in questo modo, si possono emulare le colonne di tipo Persistent. Questa soluzione è generalmente più lenta, e richiede che vengano mantenuti due trigger (indipendentemente dal numero di colonne che si desidera riempire).

Indici funzionali modifica

Gli indici funzionali sono una caratteristica di PostgreSQL. Questi sono molto simili alle colonne virtuali e spesso ne sopperiscono la mancanza. Si tratta di indici che non contengono il valore di una tabella (come gli indici normali), ma il valore di un'espressione SQL.

Collegamenti esterni modifica