Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-11-2010, 15:14   #1
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
[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 15:17.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 18-11-2010, 23:27   #2
oNaSsIs
Member
 
L'Avatar di oNaSsIs
 
Iscritto dal: Apr 2007
Messaggi: 182
Potresti gestirlo con un trigger. Prima però cerca di esporre meglio il tuo problema.
oNaSsIs è offline   Rispondi citando il messaggio o parte di esso
Old 19-11-2010, 15:11   #3
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
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à
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 19-11-2010, 22:58   #4
oNaSsIs
Member
 
L'Avatar di oNaSsIs
 
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?
oNaSsIs è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2010, 09:11   #5
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Ti posto lo script per la creazione del database.
Allegati
File Type: txt create.txt (5.8 KB, 6 visite)
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2010, 10:58   #6
oNaSsIs
Member
 
L'Avatar di oNaSsIs
 
Iscritto dal: Apr 2007
Messaggi: 182
Scusami ho dimenticato di chiederti anche:
  • qual è l'attributo derivato
  • come viene calcolato
  • quali sono le operazione che possono essere eseguite sugli attributi che lo generano
oNaSsIs è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2010, 11:20   #7
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Quote:
Originariamente inviato da oNaSsIs Guarda i messaggi
Scusami ho dimenticato di chiederti anche:
  • qual è l'attributo derivato
  • come viene calcolato
  • quali sono le operazione che possono essere eseguite sugli attributi che lo generano
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à
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2010, 12:07   #8
oNaSsIs
Member
 
L'Avatar di oNaSsIs
 
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'
le uscite:
Codice:
SELECT SUM(quantity)
FROM lineofcustomer
WHERE wine='xxx'
Prima di andare avanti vediamo se fin qui ci siamo. Scusami ma avendo solo le CREATE TABLE davanti ho difficoltà a comprendere il database nel suo complesso.
oNaSsIs è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2010, 13:42   #9
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
..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à
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2010, 15:54   #10
oNaSsIs
Member
 
L'Avatar di oNaSsIs
 
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
Il trigger è scritto per MySql, non so se tu stai usando lo stesso DBMS.
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 16:19.
oNaSsIs è offline   Rispondi citando il messaggio o parte di esso
Old 22-11-2010, 16:20   #11
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
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à
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2010, 11:48   #12
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
non riesco a scriverla in sql...
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 30-11-2010, 20:33   #13
oNaSsIs
Member
 
L'Avatar di oNaSsIs
 
Iscritto dal: Apr 2007
Messaggi: 182
Prova a dare un'occhiata a questo reference. L'idea è quella di scrivere prima una funzione che poi eseguirà il trigger ogni volta che scatta. Tu prova ad abbozzare qualcosa che poi magari la rivediamo insieme.
oNaSsIs è offline   Rispondi citando il messaggio o parte di esso
Old 03-12-2010, 22:41   #14
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
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à
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 06-12-2010, 14:05   #15
oNaSsIs
Member
 
L'Avatar di oNaSsIs
 
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.
oNaSsIs è offline   Rispondi citando il messaggio o parte di esso
Old 07-12-2010, 08:22   #16
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Mi sa che ci rinuncio...faccio prima a togliere l'attributo derivato.
Grazie comunque.
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 07-12-2010, 10:57   #17
oNaSsIs
Member
 
L'Avatar di oNaSsIs
 
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 11:16.
oNaSsIs è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Dreame H15 Mix: la soluzione 7-in-1 per ...
AirPods Pro 3 in forte sconto su Amazon:...
36 offerte Amazon, molte appena partite:...
2 caricatori multipli eccezionali: da 28...
OLED e 360 Hz a un prezzo senza preceden...
Roborock Q10 S5+ a un prezzo molto conve...
Upgrade PC a prezzo ridotto: le migliori...
Sono i 6 smartphone migliori su Amazon: ...
Google Pixel 9a a 361€, mai così ...
Super sconti sugli spazzolini Oral-B, an...
Aspira a 6000Pa, lava bene, costa 139€: ...
Nuove scorte: torna il portatile tuttofa...
Toyota usa giochi e premi per spingere i...
HarmonyOS ha raggiunto la soglia di sopr...
Le offerte Amazon più convenienti...
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: 15:30.


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