Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
realme 16 5G è un nuovo smartphone con sensore Sony IMX 852 da 50MP sul retro e uno specchio selfie fisico integrato nella camera bar, una prima nel segmento di mercato. Batteria da 6550mAh in un corpo da 8,1mm e 183g, certificazione IP69K e ricarica da 45W completano un pacchetto aggressivo per la fascia media, per uno dei prodotti più interessanti del produttore sul piano commerciale
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5 introduce Dynamic Multi Frame Generation e MFG 6X, permettendo fino a cinque frame generati per ogni frame renderizzato. I test su Cyberpunk 2077 e 007 First Light mostrano forti incrementi di FPS e riduzione della latenza su RTX 5090 Laptop. Migliorano fluidità, stabilità e qualità visiva.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-06-2009, 18:16   #1
Rintrah84
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
Rintrah84 è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2009, 18:22   #2
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
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.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2009, 18:28   #3
Rintrah84
Bannato
 
Iscritto dal: Jun 2009
Città: Roma
Messaggi: 102
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
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?
Rintrah84 è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2009, 18:51   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2790
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.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2009, 19:15   #5
Rintrah84
Bannato
 
Iscritto dal: Jun 2009
Città: Roma
Messaggi: 102
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
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?
Rintrah84 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
La NASA spiega perché non ci sono...
La NASA sta provando il Divergent Deploy...
Fidanzarsi con l'IA non è cos&igr...
AI Overviews: quando il riassunto &egrav...
Il circuito segreto di Apple finisce a W...
Disastro Meta: l'azienda elimina il rico...
Google Gemini non va: centinaia di segna...
Neural Dawn mostra il futuro del gaming ...
Telegram torna su Apple Watch con un'app...
Da oggi si può acquistare Amazon ...
Windows 11 è più veloce: implementati il...
Ritornano gli auricolari con il cavo: Te...
Insta360 Luna Ultra: ecco il debutto del...
BOOX Go 6 Gen II ufficiale: ora si scriv...
BYD sfida Tesla con un piano da 2 miliar...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 23:35.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v