Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 13-11-2008, 12:11   #1
xsatellitex
Member
 
L'Avatar di xsatellitex
 
Iscritto dal: Dec 2007
Messaggi: 190
[SQL] consiglio Prestazioni

aiuto non riesco a venirne a capo
Ho realizzato un sito web di Articoli generici.Ogni pagina del sito mostra tutte le informazioni riguardanti l'articolo.Le informazioni sono tante e per questo uso molte tabelle.

Il problema è che, per ogni pagina che viene caricata, sul lato server devo fare delle query su 6 tabelle. Le query sono semplici pero' devono esplorare l'intera tabella.
Volevo sapere a parte l'uso degli INDICI cosa potrei fare ?
Come potrei evitare di fare le query su tutte e 6 le tabelle per ogni pagina caricata ?



Ora il problema non si pone perche gli articoli sono solo qualche migliaio e anche gli utenti ma, per questioni di scalabilità, me lo pongo lo stesso

p.s. al momento non uso neanche gli INDICI perche so che quando le entry sono poche non portano a nessun incremento di prestazioni
xsatellitex è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2008, 12:17   #2
fbcyborg
Senior Member
 
L'Avatar di fbcyborg
 
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
Appena ho letto il titolo del thread ho subito pensato di indicarti l'utilizzo degli indici, ma ho visto che c'hai già pensato. Alla fine quelli ottimizzano la base di dati per query che fai molto spesso.

Un'altra cosa che potresti provare, forse, sono le viste, ma non so se alla fine possano incrementare veramente le prestazioni. Secondo me sei già sulla buona strada se usi gli indici.
__________________
^ThE CyBoRg^
fbcyborg è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2008, 12:33   #3
xsatellitex
Member
 
L'Avatar di xsatellitex
 
Iscritto dal: Dec 2007
Messaggi: 190
mmm per le view ci avevo pensato pero' siccome le query sono molto semplici non so se sono buone nel mio caso, magari le usero' per query un po piu complesse.

Ah ho dimenticato di dire una cosa.
Delle 6 tabelle la prima è quella che contiene le info riguardanti gli articoli ed è legata alle altre 5 con una relazione UNO-MOLTI .
Magari potrei mettere nella tabella articolo un campo per ognuno delle 5 tabelle e che fa riferimento alle rispettive entry nelle 5 tabelle ?

Ho detto una ca***a ?
xsatellitex è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2008, 13:58   #4
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Posta la struttura delle tabelle e un esempio di qualche query.
Se mi dici di aver definito degli indici e di aver bisogno di un full table scan vuol dire che c'è qualcosa di sbagliato a monte.

Va bene l'sql per le tabelle (create table ...eccc).
shinya è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2008, 15:26   #5
xsatellitex
Member
 
L'Avatar di xsatellitex
 
Iscritto dal: Dec 2007
Messaggi: 190
grazie per l'aiuto

tabella ARTICOLO:
id, titolo, descrizione, data inserimento,

tabella ARTICOLI_IN_ASTA
id, articolo_id , data scadenza, data inizio asta,

tabella FOTO_ARTICOLI
id, articolo_id, data scatto, luogo scatto, autore, dimensione, url foto

tabella GALLERIA_ARTICOLI
id, articolo_id, nome galleria, data creazione galleria, autore galleria, genere galleria

tabella MOSTRA_ARTICOLI
id, articolo_id, data mostra, autore mostra, luogo mostra, if_pagamento, if_pubblica



Per ogni pagina caricata deve fare una query su ogni tabella in ordine:
una per cercare l'articolo di una certa data
una per vedere se quell'articolo è in asta e se si stampare la data inizio e fine asta
una per recuperare tutte le foto appartenenti a quell articolo
una per recuperare la galleria di appartenenza e stampare info sull'autore della galleria e genere galleria
una per vedere se verra' mostrata in una mostra e recuperare le info sulla mostra.


quindi devo fare una query su ogni tabella e ogni query deve fare uno scan dell'intera tabella

p.s. c'e' anche un'altra tabella ma al momento non ce l ' ho a portata di mano
xsatellitex è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2008, 17:21   #6
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Umh...
Non mi tornano molto le relazioni tra articoli e galleria/mostra... cioè, in un una galleria ci può essere al più 1 articolo? E un articolo può stare in N gallerie? Non è che c'è un rapporto N:M vero?

Ma vabbè a parte questo...
Un'altra cosa che non ho capito è se hai bisogno di visualizzare tutte le informazioni di tutti gli articoli nella stessa pagina o se hai una pagina di dettaglio per ogni articolo.
Cmq...gli indici su cosa gli hai fatti? E per quale chiave accedi? Fammi un esempio di query...
Da quello che ho capito, avresti bisogno di un indice sulla data per la tabella degli articoli e un indice su articolo_id per le altre tabelle.

Tieni conto che il motore del db potrebbe scegliere di non usare l'indice che hai definito date le circostanze (dipende dal motore, dagli indici, e da tante cose... io posso aiutarti se usi oracle, ma gli altri non li conosco a questo livello).
shinya è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2008, 19:13   #7
xsatellitex
Member
 
L'Avatar di xsatellitex
 
Iscritto dal: Dec 2007
Messaggi: 190
ops hai ragione le relazione sono N:M per galleria/mostra e articolo.
Tutte le informazioni sugli articoli vengono visualizzate nella stessa pagina.

Gli indici non li ho fatti ancora perche le entry sono qualche migliaia e sapevo che con poche entry le prestazioni non aumentano anzi diminuiscono perche si perde tempo con l'aggiornamento degli indici a ogni update,delete,insert.

Ecco qualche query:

Select titolo,descrizione
From ARTICOLO
Where data=10-11-2008

Select data_scadenza,data_inizio
From ARTICOLIO_IN_ASTA
Where articolo_id=1115

Select url_foto, autore, data_scatto, dimensione
From FOTO_ARTICOLI
Where articolo_id=1115


Comunque se c'e' bisogno degli indici non c'e' problema ho capito come si creano e li usero' piu in la quando le entry saranno molte di piu.. a me interessava sapere se c'e' un modo, magari modificando la struttura del database, per evitare di fare delle query su tutte e 6 le tabelle per ogni pagina... magari aggiungendo altri campi alla tabella ARTICOLO boh


thanks

Ultima modifica di xsatellitex : 13-11-2008 alle 19:20.
xsatellitex è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2008, 21:05   #8
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Non vedo particolari problemi: mi sembra tutto da manuale, visto che le tabelle sono normalizzate e utilizzi giustamente gli id degli articoli.

Basta definire l'integrità referenziale con le foreign key automaticamente l'engine SQL creerà i corrispondenti indici che userà poi automaticamente.

Sta tranquillo che ogni volta che userai query che hanno Where articolo_id=1115 (cioé che selezionano un ben preciso articolo), verranno eseguite mooolto velocemente (proprio perché si usano gli indici).

Eventualmente potresti pensare di effettuare caching degli articoli utilizzati di recente, ma è molto più complicato e non credo ne valga la pena (proprio perché secondo me funzionerà bene già così).
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2008, 22:08   #9
xsatellitex
Member
 
L'Avatar di xsatellitex
 
Iscritto dal: Dec 2007
Messaggi: 190
ok allora lascio tutto com'e' magari piu in la uso gli indici.
volevo fare solo un ultima domanda :

visto che l'articolo ha anche una foto da usare come avatar quando faccio le ricerche, potrei inserire una foreign key in ARTICOLO cosi posso subito recuperare la foto avatar ?



grazie per il prezioso aiuto
xsatellitex è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2008, 22:41   #10
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Quote:
Originariamente inviato da xsatellitex Guarda i messaggi
ok allora lascio tutto com'e' magari piu in la uso gli indici.
Come avevo scritto, se definisci le foreign key l'engine SQL te li crea automaticamente.
Quote:
volevo fare solo un ultima domanda :

visto che l'articolo ha anche una foto da usare come avatar quando faccio le ricerche, potrei inserire una foreign key in ARTICOLO cosi posso subito recuperare la foto avatar ?
Certamente.
Quote:
grazie per il prezioso aiuto
Di nulla.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2008, 09:50   #11
Big Bamboo
Member
 
Iscritto dal: Jul 2008
Città: Nel mio studio
Messaggi: 168
che tecnologia server side usi?
__________________
Since Rocco Siffredi, the saying "pain in the ass" got a total new meaning
Big Bamboo è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Il telescopio spaziale James Webb ha cat...
Il razzo spaziale europeo Ariane 6 lance...
Il lander lunare Blue Origin Blue Moon M...
Gli LLM riescono a risolvere problemi ma...
Smettila con quei cioccolatini. Per San ...
Il secondo lancio del razzo spaziale eur...
MaiaSpace ed Eutelsat stringono un accor...
Motorola edge 60 neo sorprende: compatto...
Zeekr 007 e 007GT si aggiornano: piattaf...
ASUS ROG Swift OLED PG27AQWP-W: 720 Hz e...
È super il prezzo del robot rasae...
MediaTek aggiorna la gamma di Dimensity:...
Foto intime sottratte dai telefoni in ri...
In Cina approvate nuove regole per il ri...
L'accordo multi-miliardario tra Google e...
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:30.


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