|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Bannato
Iscritto dal: Jun 2009
Città: Roma
Messaggi: 102
|
[MySql] Ottimizzare le query usando le view
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 |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
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.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto. E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test. |
|
|
|
|
|
#3 | |
|
Bannato
Iscritto dal: Jun 2009
Città: Roma
Messaggi: 102
|
Quote:
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? |
|
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Nov 2005
Messaggi: 2781
|
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.
|
|
|
|
|
|
#5 | |
|
Bannato
Iscritto dal: Jun 2009
Città: Roma
Messaggi: 102
|
Quote:
|
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 11:54.




















