|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Senior Member
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2156
|
[SQL] Attributo derivato
Per l'università stiamo facendo un progetto su database (introduzuione ai database).
Inizialmente dovevamo fare l'ER e poi da quello creare tabelle e db. "Erroneamente" ho inserito un attributo derivato e ora mi tocca implementarlo. Ho letto in giro su internet per trovare qualcosa, ma tutti sconsigliano di implementarlo e perciò non trovo COME implementarlo. Chi mi sa dare una mano? EDIT: scusate per il doppione, pensavo non fosse partito.
__________________
Vendo...nulla. Cerco...la felicità. Ultima modifica di Emaborsa : 18-11-2010 alle 14:17. |
![]() |
![]() |
![]() |
#2 |
Member
Iscritto dal: Apr 2007
Messaggi: 182
|
Potresti gestirlo con un trigger. Prima però cerca di esporre meglio il tuo problema.
|
![]() |
![]() |
![]() |
#3 |
Senior Member
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2156
|
Allora, ho un campo che deve tenere il conto di "quantità". In altre tabelle vengono tenute le quantità entrate e uscite. Nel campo in questione deve risultare il calcolo tra questi 2 campi.
è abbastanza chiaro?
__________________
Vendo...nulla. Cerco...la felicità. |
![]() |
![]() |
![]() |
#4 |
Member
Iscritto dal: Apr 2007
Messaggi: 182
|
Io credo che con un trigger che catturi le operazioni di INSERT, ma non solo, questo dipende dal funzionamento del database, dovresti riuscire a calcolare quell'attributo. Potresti postarmi le CREATE TABLE delle tabelle in questione?
|
![]() |
![]() |
![]() |
#5 |
Senior Member
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2156
|
Ti posto lo script per la creazione del database.
__________________
Vendo...nulla. Cerco...la felicità. |
![]() |
![]() |
![]() |
#6 |
Member
Iscritto dal: Apr 2007
Messaggi: 182
|
Scusami ho dimenticato di chiederti anche:
|
![]() |
![]() |
![]() |
#7 |
Senior Member
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2156
|
Allora, l'attributo derivato è la quantità nella tabella wines, la quale dovrebbe venire calcolata dalle quantità entrate meno quelle uscite. Suppongo che sarà una cosa abbastanza complessa, dato che bisogna filtrare ogni riga di ogni ordine in base al tipo di "wines" contenuto in ogni lineoforder. Operazioni? ...non capisco.
__________________
Vendo...nulla. Cerco...la felicità. |
![]() |
![]() |
![]() |
#8 |
Member
Iscritto dal: Apr 2007
Messaggi: 182
|
Ok vediamo un pò se ci siamo intesi.
Tu devi calcolare l'attributo wines.quantity sottraendo a questa quantità delle entrate (suppongo che più produttori possano produrre uno stesso vino): Codice:
SELECT SUM(quantity) FROM lineofproducer WHERE wine='xxx' Codice:
SELECT SUM(quantity) FROM lineofcustomer WHERE wine='xxx' |
![]() |
![]() |
![]() |
#9 |
Senior Member
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2156
|
..no proprio. Io ho una tabella che si chiama WINES con vari attributi, tra i quali QUANTITY ON STOCK di bottiglie di vino. questa quantity on stock deve prendere vaolre da altri attributi:
il movimento delle bottiglie si trovano nelle tabelle linoofproducer e lineof customer, uno tiene le quantità in entrata e l'altra in uscita. devo fare la somma di una - la somma dell'altra e riportarla in QUANTITY ON STOCK. meglio?
__________________
Vendo...nulla. Cerco...la felicità. |
![]() |
![]() |
![]() |
#10 |
Member
Iscritto dal: Apr 2007
Messaggi: 182
|
A me sembra di aver detto la stessa cosa sopra.
Comunque guarda questo è il trigger che ho scritto. Purtroppo non avendo un db su cui testarlo non posso assicurarti che funzioni, questo me lo dirai tu. Codice:
CREATE TRIGGER AFTER INSERT ON lineofproducer FOR EACH ROW BEGIN DECLARE quantityProducer INT; DECLARE quantityCustomer INT; SELECT SUM(quantity) INTO quantityProducer FROM lineofproducer WHERE wine = NEW.wine AND vintage = NEW.vintage; SELECT SUM(quantity) INTO quantityCustomer FROM lineofcustomer WHERE wine = NEW.wine AND vintage = NEW.vintage; UPDATE wines SET quantity = quantityProducer + quantityCustomer WHERE wine = NEW.wine AND vintage = NEW.vintage; END Ogni volta che fai una INSERT nella tabella lineofproducer questo scatta e esegue due select, la prima restituisce la sommatoria delle quantità lineofproducer del vino che hai appena inserito. Dopodiché esegue la stessa query sulla tabella lineofcustomer. A questo punto applica un UPDATE sulla tabella wines alla tupla contenente il vino aggiunto nell'ordine. Un trigger analogo andrebbe poi aggiunto anche all'altra tabella, lineofcustomer, e anche per l'operazione di UPDATE, ma facciamo un passo per volta. Ultima modifica di oNaSsIs : 20-11-2010 alle 15:19. |
![]() |
![]() |
![]() |
#11 |
Senior Member
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2156
|
Innanzi tutto grazie.
Sto usando SQL tramite postgres, il MySQL se non erro non è proprio uguale...proverò a tradurlo ma non so se riuscirò. Ti faccio sapere.
__________________
Vendo...nulla. Cerco...la felicità. |
![]() |
![]() |
![]() |
#12 |
Senior Member
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2156
|
non riesco a scriverla in sql...
__________________
Vendo...nulla. Cerco...la felicità. |
![]() |
![]() |
![]() |
#14 |
Senior Member
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2156
|
Ho provato. Da quello che ho capito, in SQL nei trigger non posso mettere DECLARE. Penso di dover prima creare una FUNCTION e quella viene richiamata da un trigger. o sbaglio?
__________________
Vendo...nulla. Cerco...la felicità. |
![]() |
![]() |
![]() |
#15 |
Member
Iscritto dal: Apr 2007
Messaggi: 182
|
In MySql scrivevo direttamente dentro il trigger il codice da eseguire (comprese eventuali dichiarazioni), nell'esempio che ti ho linkato prima, su PostgreSql, però fa come hai detto tu, prima scrive la funzione e poi il trigger che la esegue.
|
![]() |
![]() |
![]() |
#16 |
Senior Member
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2156
|
Mi sa che ci rinuncio...faccio prima a togliere l'attributo derivato.
Grazie comunque.
__________________
Vendo...nulla. Cerco...la felicità. |
![]() |
![]() |
![]() |
#17 |
Member
Iscritto dal: Apr 2007
Messaggi: 182
|
Valuta tu, perchè in realtà non è difficile, sono da fare due select e un update. Io purtroppo in questi giorni sono molto impegnato e dovrei studiarmi prima di tutto la sintassi e non avendo modo di testarla potrebbe servirmi più tempo del necessario, però se dovessero scapparmi due minuti posso provare ad abbozzare qualcosa.
Ultima modifica di oNaSsIs : 07-12-2010 alle 10:16. |
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 21:51.