PDA

View Full Version : [MySql] Ottimizzare le query usando le view


Rintrah84
16-06-2009, 19:16
Salve,
stò facendo un progetto per un secondo esame universitario relativo ai database.

L'esame consiste principalmente nell'ottimizzare un progetto in 2 modi:

1) Ottimizzazione del database inserendo degli indici sulle tabelle (e vabbè, no problem).

2) Ottimizzazione delle query usando le view.

Ho qualche problema a capire questa seconda cosa poichè mi sono perso la lezione.

Intanto ditemi se ho capito bene: una view è come se fosse una tabella virtuale che può mascherarmi parte della tabella fisica.

Ad esempio se ho una tabella UTENTE formata dai seguenti campo: Nome, Cognome, Data_Nascita, Codice_Fiscale, Indirizzo, Cap una sua view potrebbe essere una tabella virtuale che mi mostra solamente alcuni campi come ad esempio: Nome, Cognome, Data_Nascita

Questo perchè può essere importante preservare alcuni dati che si vogliono memorizzare ma che non si vogliono far vedere agli utenti che eseguono le query (ad esempio per motivi di privacy)....quindi si usano le view per restituire dei risultati mascherati....è corretta come cosa o è campata in aria?

Un altro motivo per usare le view (il mio scopo) è appunto per l'ottimizzazione delle query...credo infatti che se vado a fare query su delle view che contengono pezzi parziali di tabelle non devo caricare tutti i campi dei vari record in memoria e ciò fa sprecare meno spazio...così magari faccio dei join su tabelle parziali e c'è anche un risparmio di tempo relativo al fatto che carico meno roba rispetto alla tabella originale....

E' questo il discorso che ci stà dietro all'ottimizzazione delle query usando le view o mi son perso qualcosa?

Grazie

gugoXX
16-06-2009, 19:22
L'uso delle view non e' un uso per ottimizzare le performance, ma al limite solo per organizzare meglio le strutture.
Motivi di sicurezza di colonna, riduzione del codice da manutenere, chiarezza di lettura del codice che ne fa uso.
Ma non le performance.
In passato si poteva vedere una parte di performance migliorata perche' la query e' gia' parsificata, ma sono tempi che oggi sono nascosti e ridicoli.

Quando un engine si trova davanti una vista conivolta in una query piu' complessa, semplicemente sostituisce il corpo della vista nella query piu' complessa, e valuta il tutto.

La vista non occupa spazio dati, a parte il necessario per il manentimento della vista stessa nei dizionari.
E' solo uno shortcut.

Rintrah84
16-06-2009, 19:28
L'uso delle view non e' un uso per ottimizzare le performance, ma al limite solo per organizzare meglio le strutture.
Motivi di sicurezza di colonna, riduzione del codice da manutenere, chiarezza di lettura del codice che ne fa uso.
Ma non le performance.
In passato si poteva vedere una parte di performance migliorata perche' la query e' gia' parsificata, ma sono tempi che oggi sono nascosti e ridicoli.

Quando un engine si trova davanti una vista conivolta in una query piu' complessa, semplicemente sostituisce il corpo della vista nella query piu' complessa, e valuta il tutto.

La vista non occupa spazio dati, a parte il necessario per il manentimento della vista stessa nei dizionari.
E' solo uno shortcut.

Cioè cosa intendi con uno shortcut?

Praticamente mi stai dicendo che se io faccio una query che ad esempio coinvolge solo determinati campi di 2 tabelle (non tutti i campi) l'engine crea automaticamentele view delle tabelle e su queste esegue la query?

Se intendi questo...come cavolo glielo spiego alla proff che lo fa direttamente l'egine visto che lei ha fatto una lezione su sta cosa e pretende che nel progetto facciamo questa procedura per ottimizzare le query? :muro: :eek: :eek: :eek:

wingman87
16-06-2009, 19:51
No, praticamente la view è una query, quando la utilizzi in altre query l'engine non fa altro che sostituire le occorrenze della view con la query ad essa associata. Per questo migliora la leggibilità e quindi la manutenibilità ma non migliora le performance.

Rintrah84
16-06-2009, 20:15
No, praticamente la view è una query, quando la utilizzi in altre query l'engine non fa altro che sostituire le occorrenze della view con la query ad essa associata. Per questo migliora la leggibilità e quindi la manutenibilità ma non migliora le performance.

Oddio...il dramma è che io sono sicuro che ha chiesto l'ottimizzazione delle query usando le view...pff corso tenuto maluccio...che mi invento ora?