Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Polestar 3 Performance, test drive: comodità e potenza possono convivere
Polestar 3 Performance, test drive: comodità e potenza possono convivere
Abbiamo passato diversi giorni alla guida di Polestar 3, usata in tutti i contesti. Come auto di tutti i giorni è comodissima, ma se si libera tutta la potenza è stupefacente
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
In occasione del proprio Architecture Deep Dive 2025 Qualcomm ha mostrato in dettaglio l'architettura della propria prossima generazione di SoC destinati ai notebook Windows for ARM di prossima generazione. Snapdragon X2 Elite si candida, con sistemi in commercio nella prima metà del 2026, a portare nuove soluzioni nel mondo dei notebook sottili con grande autonomia
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
DJI Mini 5 Pro porta nella serie Mini il primo sensore CMOS da 1 pollice, unendo qualità d'immagine professionale alla portabilità estrema tipica di tutti i prodotti della famiglia. È un drone C0, quindi in un peso estremamente contenuto e che non richiede patentino, propone un gimbal rotabile a 225 gradi, rilevamento ostacoli anche notturno e autonomia fino a 36 minuti. Caratteristiche che rendono il nuovo drone un riferimento per creator e appassionati
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 07-10-2012, 19:03   #1
Lwyrn
Senior Member
 
L'Avatar di Lwyrn
 
Iscritto dal: Jan 2009
Città: Verona
Messaggi: 2514
[PHP+MySQL]Database, lingue e capocciate

Sto mettendo insieme un piccolo sistema che ( in teoria ) dovrebbe gestire migliaia di prodotti e di pagine di testo che però possono essere localizzate in un numero indefinito di lingue ( dinamicamente a scelta dell'amministratore ).
Sono un bel pò dubbioso sul tipo di sistema da utilizzare perché ognuna delle soluzioni che mi vengono in mente hanno tanti contro quanti pro. Prendete in considerazione che le "estensioni" che si occupano delle gestione dei vari compenti ( es prodotti, news etc. ) devono gestire automaticamente l'implementazione del numero indefinito di lingue. Quindi non posso preventivare campi specifici che andranno a gestire le rispettive lingue.
Di base ho pensato che viene definita una lingua principale dall'amministratore o dal sistema stesso. E questo mi pare anche abbastanza scontato
In anticipo ho pensato di creare un apposita colonna dedicata ( per ogni tabella che ne abbia la necessità ) per contenere array multidimensionali serializzati che contengono tutte le parti localizzate necessarie ( ad esempio titolo, descrizione o cos'altro ).
Potrebbe rivelarsi una situazione comoda per quanto riguarda la gestione da php che diventa molto più scorrevole e la pulizia nel database.
Diventa assolutamente scomodo però quando si comincia a voler fare query personalizzate per estrarre dati in determinati lingue. Ergo, diventa abbastanza difficile da gestire se si vogliono fare campi personalizzati di ricerca nel sito per lingue diverse da quella standard. Si dovrebbe cominciare a lavorare con query che sfruttano espressioni regolari per farsi strada tra la lunga stringa che verebbe fuori da un array serializzato, con conseguenti rallentamento delle query che, sopratutto su migliaia di articoli, comincerebbe a rallentarsi un bel pò. Per non considerare la limitazione che si avrebbe nel non poter usare istruzioni piu complesse.
Altra soluzione a cui ho pensato è quella di far creare ( si parla sempre in modo dinamico ) dal sistema n. tabelle per quante sono le lingue con un prefisso contenente il distintivo della lingua ( es products_it, product_es, products_en etc ). I pro sono ovviamente di poter fare delle semplicissime query cambiando solo il prefisso della tabella in caso si vogliano ricercare dati o effettuare query più complesse. Aumenterebbero però la difficoltà nella gestione del tutto. Si ci dovrebbe assicurare di far combaciare gli id della lingua principale con quelli delle tabelle secondarie, assicurarsi di cancellare le righe simultaneamente e aggiungere dei flag-field per determinare se un determinato prodotto è presente o meno in quella determinata lingua. Per non parlare dell'enormità di tabelle che ne uscirebbero fuori e sopratutto delle dimensioni: si arriverebbe a duplicare, triplicare, quadruplicare e così via la dimensione del database in base al numero di lingue utilizzate.
Altri metodi al momento non me ne sono venuti, però vorrei fare in modo di poter gestire il tutto cercando di aver un buon rapporto prestazioni/facilità di gestione, e sono parecchio indeciso.
Voi che dite, avete qualche idea da consigliarmi ? Qualsiasi idea è ben accetta!
__________________
Le mie trattative
Lwyrn è offline   Rispondi citando il messaggio o parte di esso
Old 07-10-2012, 19:37   #2
VICIUS
Senior Member
 
L'Avatar di VICIUS
 
Iscritto dal: Oct 2001
Messaggi: 11471
Che ne dici di questo?

Una tabella prodotto che contiene tutto quello che non serve tradurre. Una per la lista delle lingue. E poi metti tutti i dati tradotti in una terza tabella che ha come chiave primaria l'id del prodotto e della lingua.
VICIUS è offline   Rispondi citando il messaggio o parte di esso
Old 07-10-2012, 20:02   #3
Lwyrn
Senior Member
 
L'Avatar di Lwyrn
 
Iscritto dal: Jan 2009
Città: Verona
Messaggi: 2514
Quote:
Originariamente inviato da VICIUS Guarda i messaggi
Che ne dici di questo?

Una tabella prodotto che contiene tutto quello che non serve tradurre. Una per la lista delle lingue. E poi metti tutti i dati tradotti in una terza tabella che ha come chiave primaria l'id del prodotto e della lingua.
Ummm, sicuramente molto meglio che duplicare intere tabelle! E si potrebbe collegare il tutto con delle join, sicuramente molto meno disordinato che creare trecentomila tabelle. Hai usato MysqlWorkbench per lo schema ?
__________________
Le mie trattative
Lwyrn è offline   Rispondi citando il messaggio o parte di esso
Old 07-10-2012, 20:04   #4
VICIUS
Senior Member
 
L'Avatar di VICIUS
 
Iscritto dal: Oct 2001
Messaggi: 11471
Esatto.
VICIUS è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026 Qualcomm Snapdragon X2 Elite: l'architettura del...
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice Recensione DJI Mini 5 Pro: il drone C0 ultra-leg...
ASUS Expertbook PM3: il notebook robusto per le aziende ASUS Expertbook PM3: il notebook robusto per le ...
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
DAZN continua la lotta contro la pirater...
Generativa o predittiva? Il futuro dell’...
BYD va all-in con la Atto 2: batteria pi...
Google modifica la richiesta di consenso...
Black Friday TV: OLED, QLED e Mini-LED a...
007 First Light torna a mostrarsi all'ev...
MOVA Z60 Ultra Roller Complete: il Black...
Clair Obscur: Expedition 33 trionfa ai G...
Son quasi regalate: 135€ per le Squier b...
Windows 11: il copia-incolla via IA funz...
La scopa elettrica Mova K30 Mix crolla a...
Violazione in Almaviva, fornitore IT di ...
Amazon avvia un investimento da 3 miliar...
Ci fai tutto e ci giochi bene: a 999€ po...
Snapdragon o Exynos? Un sondaggio svela ...
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: 11:04.


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