|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Sep 2004
Messaggi: 3967
|
[MySql]Suggerimenti struttura tabella
Buondì a tutti .
Per me è quasi un 3d ciclico, ma il problema che da tempo mi trovo ad affrontare, è per me una sfida ancora non vinta ed io non sono ancora stato capace di trovare una soluzione al problema. In sintesi: devo gestire le ore lavorate di altri utenti, gestirne le assenze, i permessi, le malattie etc... presso sedi di lavoro che possono essere diverse da quella centrale. Per ragioni che non sto qui a spiegare, prima c'era una struttura che non potevo modificare (nel db), ed era, per quanto io sia l'ultima ruota del carro, davvero progettata da cani. Altri utenti di questa sezione si ricorderanno i 3d in cui chiedevo aiuto e di come le tabelle fossero strutturate male. Bene... ora tocca a me (quindi.. male Per memorizzare il lavorato, avevo pensato ad una tabella così strutturata: Codice:
id_lavoro - pk id_utente -> (pk della tabella utenti) id_sede -> (pk della tabella sedi) id_categoriaLavoro -> (pk della tabella categorieLavori) data ->datetime parametroBase ->double ->(prende il valore dalla scheda utente, se presente) lavoratoExtra ->double ->(se ha lavorato in più del dovuto) totale -> double(eventuale somma tra parametroBase ed Extra oppure inserimento diretto in assenza di parametri) maggiorazione int -> maggiorazione in percentuale in base al tipo di extra codiceAssenza -> varchar -> in caso di assenza viene scelto un valore 1)Devo tirare fuori un tabulato mensile che raggruppi tutti gli utenti che hanno lavorato durante un determinato mese, ed avere una visualizzazione a prescindere che ci siano dei giorni lavorati o meno, mi spiego meglio: utente: pippo data: 07/07/2008, 08/08/20008 io devo comunque visualizzare i dati in modo che ci siano tutti i giorni del mese e mettere il totale in corrispondenza del giorno lavorato. Parto con questa prima domanda e poi vedremo Grazie mille RaouL.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
|
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Aug 2005
Città: Wien
Messaggi: 435
|
Uhm, non mi sono chiare alcune cose:
__________________
"Sono 126 miglia per Chicago. Abbiamo il serbatoio pieno, mezzo pacchetto di sigarette, è buio, e portiamo tutt'e due gli occhiali da sole" |
|
|
|
|
|
#3 | |
|
Senior Member
Iscritto dal: Sep 2004
Messaggi: 3967
|
Quote:
La 'tripletta' la prende solo dalle altre tabelle ma senza essere chiavi primarie in questa.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
|
|
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Aug 2005
Città: Wien
Messaggi: 435
|
Scusami se insisto, ma voglio capire una cosa... Tu per ogni lavoro hai un solo lavoratore assegnato ad esso?
__________________
"Sono 126 miglia per Chicago. Abbiamo il serbatoio pieno, mezzo pacchetto di sigarette, è buio, e portiamo tutt'e due gli occhiali da sole" |
|
|
|
|
|
#5 | |
|
Senior Member
Iscritto dal: Sep 2004
Messaggi: 3967
|
Quote:
Faccio un esempio: CategorieLavori: FRESATURA LUCIDATURA SALDATURA etc.. un utente può svolgere uno, o tutti i lavori presenti nelle categorie.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
|
|
|
|
|
|
|
#6 |
|
Senior Member
Iscritto dal: Aug 2005
Città: Wien
Messaggi: 435
|
Non era questo quello che intendevo. Quello che intendevo è che tu non puoi avere una situazione di questo genere nel tuo db:
Codice:
id_lavoro = 1 = FRESATURA
id_utente = 2 = pippo
id_utente = 3 = paperino
id_lavoro | id_utente
1 2
1 3
Ponendo il caso sia giusto e che la data indichi il giorno di inizio del lavoro, un esempio di query può essere: Codice:
SELECT id_lavoratore FROM nome_tabella AS t WHERE t.date BETWEEN xx/xx/xxxx AND yy/yy/yyyy GROUP BY id_lavoratore Giorgio
__________________
"Sono 126 miglia per Chicago. Abbiamo il serbatoio pieno, mezzo pacchetto di sigarette, è buio, e portiamo tutt'e due gli occhiali da sole" |
|
|
|
|
|
#7 | |
|
Senior Member
Iscritto dal: Nov 2004
Città: Padova
Messaggi: 2342
|
Quote:
Hai provato a costruire un modello concettuale del database ? Per fare un lavoro fatto bene dovresti inoltre studiarti un pò le forme normali... per esempio l'attributo "totale" non rispetta la terza forma normale perchè è un attributo non chiave che dipende da altri attributi non chiave ("parametroBase" e "lavoroExtra"). Infatti "totale" lo ricavi tranquillamente con un sum tra i due valori. Sarebbe utile capire come sono messe anche le altre tabelle.
__________________
CPU Ryzen 2600 @ 3,95Ghz + Bequiet Dark Rock TF / MB Asus X470-F Gaming / RAM 2x8GB DDR4 G.Skill FlareX 3200 CL14 / VGA Sapphire RX 7900 XT Nitro+ @ 3200Mhz / SSD Samsung 970 Pro 512GB + Sandisk 240GB Plus + Sandisk 960GB Ultra II PSU Seasonic Platinum P-660 / Headset Kingston HyperX Flight |
|
|
|
|
|
|
#8 |
|
Senior Member
Iscritto dal: Sep 2004
Messaggi: 3967
|
ah ecco, capisco il vostro dubbio
la pk la potrei chiamare anche semplicemente 'contatore'. Avevo capito ci si riferisse all'id_categoriaLavoro. L'avevo pensata così perchè quando si compila la scheda, lo si fa una persona per volta, cioè l'utente deve compilare una scheda per ogni singola persona.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
|
|
|
|
|
|
#9 |
|
Senior Member
Iscritto dal: Aug 2005
Città: Wien
Messaggi: 435
|
Beh allora direi che la query diventerà qualcosa di simile a:
Codice:
SELECT id_utente FROM nome_tabella AS t WHERE t.date BETWEEN xx/xx/xxxx AND yy/yy/yyyy GROUP BY id_utente
__________________
"Sono 126 miglia per Chicago. Abbiamo il serbatoio pieno, mezzo pacchetto di sigarette, è buio, e portiamo tutt'e due gli occhiali da sole" |
|
|
|
|
|
#10 |
|
Senior Member
Iscritto dal: Sep 2004
Messaggi: 3967
|
Stamattina, rileggendo meglio il tutto, mi sono più chiare determinate cose:
allora, l'id_lavoro è come se fosse il numero di una fattura. Ora, per la singolare necessità dell'utente di inserire una sola scheda per volta, relativa quindi ad un solo dipendente per volta, è corretto utilizzare l'id_lavoro come chiave primaria ?
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
|
|
|
|
|
|
#11 |
|
Senior Member
Iscritto dal: Aug 2005
Città: Wien
Messaggi: 435
|
Siccome da quello che ho capito ci sono più dipendenti per ogni singolo id_lavoro, è sbagliato. La chiave primaria dovrebbe essere (id_lavoro, id_dipendente).
__________________
"Sono 126 miglia per Chicago. Abbiamo il serbatoio pieno, mezzo pacchetto di sigarette, è buio, e portiamo tutt'e due gli occhiali da sole" |
|
|
|
|
|
#12 | |
|
Senior Member
Iscritto dal: Sep 2004
Messaggi: 3967
|
Quote:
lun1 mar2 mer3 gio4 ven5 sab6 dom7 lun8 etc....
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
|
|
|
|
|
|
|
#13 |
|
Senior Member
Iscritto dal: Sep 2004
Messaggi: 3967
|
No, non ci sono più dipendenti per un singolo id_lavoro. Ripeto, l'id_lavoro è relativo solo e soltanto alla scheda che viene compilata per un unico utente.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
|
|
|
|
|
|
#14 |
|
Senior Member
Iscritto dal: Aug 2005
Città: Wien
Messaggi: 435
|
Ok, allora la tabella dovrebbe andare bene. Fosse in te proverei a convertirla in una forma normale come è stato suggerito prima, ma non so se ti serva.
Per la query prova così allora: Codice:
SELECT t.id_utente, t.date FROM nome_tabella AS t WHERE t.date BETWEEN xx/xx/xxxx AND yy/yy/yyyy GROUP BY t.id_utente, t.date
__________________
"Sono 126 miglia per Chicago. Abbiamo il serbatoio pieno, mezzo pacchetto di sigarette, è buio, e portiamo tutt'e due gli occhiali da sole" |
|
|
|
|
|
#15 | |
|
Senior Member
Iscritto dal: Sep 2004
Messaggi: 3967
|
Quote:
In sostanza, ci sono dei giorni dove l'utente non ha lavorato, ma a prescindere dal fatto che in corrispondenza della data ci sia un valore o meno, io devo visualizzare tutti i giorni. In pratica, devo tirar fuori un calendario che abbia come nome delle colonne, il nome ed il numero dei giorni del mese selezionato e, all'interno di questi giorni, visualizzare il totale del lavorato dove presente. Ora capisco perchè chi aveva progettato in precedenza la tabella, anzichè avere un campo di tipo date, aveva messo: anno int mese int giorno int
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
|
|
|
|
|
|
|
#16 |
|
Senior Member
Iscritto dal: Sep 2004
Messaggi: 3967
|
uppettino.....
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
|
|
|
|
|
|
#17 |
|
Senior Member
Iscritto dal: Sep 2004
Messaggi: 3967
|
ri-uppete
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
|
|
|
|
|
|
#18 |
|
Member
Iscritto dal: Aug 2005
Messaggi: 306
|
Non so se posso aiutarti ma ci provo.
Per la visualizzazione fai un'interfaccia web o qualcosa di simile? Perchè tirare fuori anche le date dove non ci sono dati non so se è possibile utilizzando solo MySql...
__________________
... I believe in miracles / I believe in a better world / for me and you ... ...Music is like sunrise for me / it's joyful like a trip in a time machine... ...Sei solo corri, corri, corri, corri / Non ti voltare mai... |
|
|
|
|
|
#19 | |
|
Senior Member
Iscritto dal: Sep 2004
Messaggi: 3967
|
Quote:
Comunque, la tabella l'ho cambiata, al posto di date, ho optato per: anno = int mese = int giorno = int
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
|
|
|
|
|
|
|
#20 | |
|
Member
Iscritto dal: Aug 2005
Messaggi: 306
|
Quote:
Io ti scrivo comunque quello che avevo in mente, nel caso avessi tenuto il campo date: fare un array (nel linguaggio che usi) con le date comprese nel periodo che ti interessa. Poi fare un for su questo array e controllare se nella tabella c'è un valore per la data presente nell'array. Se si, visualizzi il valore, altrimenti no. Questo andrebbe fatto facendo ogni volta una query nel for, e potrebbe diventare pesantuccia l'applicazione, ma è la cosa più semplice. Altrimenti metti i valori tirati fuori dalla query generale (quella con tutti i valori compresi nel range di date) in una struttura (non so se tutti i linguaggi le supportano) e poi controlli se il valore è presente nella struttura. Se si, visualizzi il valore, altrimenti no.
__________________
... I believe in miracles / I believe in a better world / for me and you ... ...Music is like sunrise for me / it's joyful like a trip in a time machine... ...Sei solo corri, corri, corri, corri / Non ti voltare mai... |
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 22:42.




















