Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-12-2006, 18:27   #1
anonimizzato
 
Messaggi: n/a
[DB] Normalizzazione

Ciao a tutti,

avrei una domanda da fare circa il processo di normalizzazione.

Ho un DB che presenta tra le altre cose una tabella apposita per i PROGRAMMI dei CORSI di un'associazione.

Questa tabella è composta da:

-PROGRAMMI-
ID programma
ID Livello (chiave esterna presa dalla tabella dei Livelli dei vari corsi)
Oraro di inizio
Orario di fine

es:

"Corso di Inglese"

"Programma1":
-Livello Base
-dalle 17.00 alle 18.00
-martedì e giovedì.

Quello che vorrei sapere è relativo ai GIORNI ovvero, un programma si può tenere in 1 o più giorni alla settimana per tutto l'anno così come, ovviamente, i vari giorni saranno associati a diversi programmi.

Quella che si viene a creare è quindi una relazione MOLTI a MOLTI M:N (tra programmi e giorni) ma la domanda è:

Come si gestiscono le relazioni M:N per quegli intervalli di valori FINITI e comuni come appunto i giorni della settimana o i mesi dell'anno ecc.


io ho creato 3 tabelle
PROGRAMMI (vedi sopra)
PROGRAMMI_GIORNI (ID programma, ID giorno)
GIORNI (ID giorno, nome_del_giorno).

ma avrei forse potuto anche fare:
PROGRAMMI (vedi sopra)
PROGRAMMI_GIORNI (ID programma, nome_del_giorno)

avrei una ridondanza nei nomi dei giorni es:
1 - lunedì
1 - giovedì
2 - martedì
3 - lunedì
3 - martedì
...

ma una tabella in meno!

oppure:
PROGRAMMI (ID programma,ora inizio,ora fine,livelloID,lunedì,martedì,mercoledì ....)

con 7 campi da "spuntare" a seconda dei giorni interessati dal programma.


In definitiva:

In un caso "normale" laddove la seconda tabella può aumentare i propri valori il modo più corretto è quello di avere i valori in una tabella a parte e risolvere M:N con una tabella di collegamento ma in questo caso che sò per certo che i valori non cambiano come si procede nel modo più corretto con l'opera di normalizzazione?

GIORNI può essere definito a tutti gli effetti un "SOGGETTO" della base dati e quindi meritare una tabella a se?!

Spero di essere stato sufficientemente chiaro e vi ringrazio anticipatamente per le risposte.
  Rispondi citando il messaggio o parte di esso
Old 17-12-2006, 20:13   #2
giannola
Senior Member
 
L'Avatar di giannola
 
Iscritto dal: Oct 2005
Città: Palermo
Messaggi: 2579
in linea concettuale si, nel senso che i giorni sono entità, però poichè non variano(ovvero sono al massimo 7), nella normalizzazione fai prima a fare due campi testuali uno relativo agli orari ed uno relativo ai giorni.
__________________
Utente gran figlio di Jobs ed in via di ubuntizzazione
Lippi, perchè non hai convocato loro ?
giannola è offline   Rispondi citando il messaggio o parte di esso
Old 18-12-2006, 08:59   #3
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da Sgurbat
PROGRAMMI (vedi sopra)
PROGRAMMI_GIORNI (ID programma, nome_del_giorno)
Va bene così, a meno che tu non voglia determinare un vincolo sull'inserimento dei dati nella relazione...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 18-12-2006, 12:02   #4
giannola
Senior Member
 
L'Avatar di giannola
 
Iscritto dal: Oct 2005
Città: Palermo
Messaggi: 2579
Quote:
Originariamente inviato da cionci
Va bene così, a meno che tu non voglia determinare un vincolo sull'inserimento dei dati nella relazione...
se segui il consiglio di cionci non dimenticare di aggiungere nella tabella PROGRAMMI_GIORNI anche ora_inizio e ora_fine
__________________
Utente gran figlio di Jobs ed in via di ubuntizzazione
Lippi, perchè non hai convocato loro ?
giannola è offline   Rispondi citando il messaggio o parte di esso
Old 18-12-2006, 12:44   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da giannola
se segui il consiglio di cionci non dimenticare di aggiungere nella tabella PROGRAMMI_GIORNI anche ora_inizio e ora_fine
Se l'orario è costante va bene dove l'ha messo, anzi è la selta migliore...
La tabella PROGRAMMI_GIORNI diventa tuttachiave...

Ultima modifica di cionci : 18-12-2006 alle 12:47.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 18-12-2006, 17:59   #6
anonimizzato
 
Messaggi: n/a
Quote:
Originariamente inviato da cionci
Se l'orario è costante va bene dove l'ha messo, anzi è la selta migliore...
La tabella PROGRAMMI_GIORNI diventa tuttachiave...
In che senso se l'orario è costante?

Grazie a tutti per le risposte.

Alla luce di tutto ciò mi pare che chiaro allora che alla fine quando si lavora con una base dati i cui i dati incrociano spesso con elementi temporali come appunto GIORNI, MESI, ANNI (in range fisso) essi vanno trattati come Entità a parte e quindi scomposti in singole tabelle giusto?

Scusate ma sono niubbo ed autodidatta su ste cose.


Ultima modifica di anonimizzato : 18-12-2006 alle 18:02.
  Rispondi citando il messaggio o parte di esso
Old 18-12-2006, 18:05   #7
anonimizzato
 
Messaggi: n/a
Quote:
Originariamente inviato da cionci
Va bene così, a meno che tu non voglia determinare un vincolo sull'inserimento dei dati nella relazione...
Uhm ... nel senso di accettare solo i valori che IO ho definito nella tabella GIORNI e non tramite l'input dell'utente?

Teoricamente questa cosa sarebbe bypassabile dall'interfaccia utente ad esempio una select con valori predefiniti o meglio ancora vista la scelta multipla dei checkbox.
  Rispondi citando il messaggio o parte di esso
Old 18-12-2006, 18:09   #8
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da Sgurbat
Teoricamente questa cosa sarebbe bypassabile dall'interfaccia utente ad esempio una select con valori predefiniti o meglio ancora vista la scelta multipla dei checkbox.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 18-12-2006, 18:10   #9
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da Sgurbat
In che senso se l'orario è costante?
Costante rispetto ai giorni... Cioè se per tutti i giorni in cui c'è un determinato corso l'orario è sempre lo stesso...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 18-12-2006, 18:57   #10
anonimizzato
 
Messaggi: n/a
Quote:
Originariamente inviato da cionci
Costante rispetto ai giorni... Cioè se per tutti i giorni in cui c'è un determinato corso l'orario è sempre lo stesso...
Si è così l'orario è fisso per il CORSO o meglio il singolo PROGRAMMA perchè per corso intedo la categoria dei vari livelli disponibili.

Cmq ok capito.

P.S.
Avreste qualche buona risorsa sia sul web che digitale da indicarmi circa il processo di progettazione e normalizzazione di un DB?

Ho già letto "Progettare Database" di M.Hernandez (davvero ottimo) ma vorrei andare oltre. Nulla di troppo complicato però non ho conoscenze ed esigenze di tipo universitario.

Bye.
  Rispondi citando il messaggio o parte di esso
Old 18-12-2006, 19:28   #11
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quel libro che hai studiato tratta le forme normali ?
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 19-12-2006, 19:38   #12
anonimizzato
 
Messaggi: n/a
Quote:
Originariamente inviato da cionci
Quel libro che hai studiato tratta le forme normali ?
Diciamo di si, anche se non in modo "accademico" o per meglio dire scentifico:

es:
"Una base dati si può definire in 1NF se ... ecc."

Nel libro, indicato per chi non abbiamo conoscienze specifiche, viene trattato il processo di progettazione con un metodo "innovativo" di linee guide basate sul "prototipo di tabella ottimale".

Da ciò ne derivano comunque le indicazioni sulla risoluzione dei campi multivalore, delle relazioni M:N come si tratterebbero in ogni altro caso.

Mi piacerebbe andare, se possibile, più sul tecnico senza addentrarmi in dettagli matematici troppo ostici come algoritmi ecc.

Diciamo che per il momento conosco l'ABC, ora vorrei impare "DEF".

Grazie ancora.
  Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Xiaomi 17 Ultra promosso da DXOMARK ma i...
iPad Mini: nuova generazione in arrivo, ...
Offerta TOP: Xiaomi Redmi Note 15 Pro 5G...
POCO X8 Pro: confermate le specifiche de...
Nothing 'cancella' Apple e annuncia la d...
Ora è ufficiale: anche Steam Deck...
2 tablet 8GB/256GB Full HD e 4G LTE in s...
Paramount non molla Warner Bros: ha 7 gi...
Hyundai: spunta un'elettrica estremament...
Una connessione diretta con AWS European...
La Toyota Yaris avrà una versione...
Minori sessualizzati da Grok: l'UE mette...
NIO stabilisce il nuovo record di scambi...
Dell Private Cloud sempre più ape...
Ennesimo incidente per la guida autonoma...
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: 09:15.


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