Italian community of Lazarus and Free Pascal

Programmazione => Databases => Topic aperto da: orestjump - Gennaio 07, 2012, 04:13:45 pm

Titolo: Campi calcolati
Inserito da: orestjump - Gennaio 07, 2012, 04:13:45 pm
Dopo aver provato e letto riguardo a Zeos e Lazarus,
dopo essermi bloccato alla Zconnection a Firebird 2.5 la quale visualizza i messaggi noti di dll non trovate,
dopo aver letto i vs post su Zeos,
ritengo che sia meglio provare con SqlDb.

Ho una query, una griglia con cui apporto modifiche ed inserimenti. Tutto ok.
Appena nella query aggiungo un campo calcolato

select doc_det.*, qta * prezzo as valore
from doc_det
where id_doc=:par1;
   

l'applyupdate segnala un errore sul campo valore

Come gestire i campi calcolati?

Grazie
Titolo: Re:Campi calcolati
Inserito da: xinyiman - Gennaio 07, 2012, 08:55:43 pm
Ma scusa, un campo calcolato non può essere aggiornato!
Titolo: Re:Campi calcolati
Inserito da: orestjump - Gennaio 08, 2012, 05:04:06 pm
Chiaro, ...che sbadato.
Tempo fa, con delphi, legavo 2 tabelle i master/detail, nella tabella di dettaglio aggiungevo dei campi calcolati e tutto funzionava bene.
La relazione master/detail si simula facilmente.
Ma come gestire campi calcolati con SQLDB (visto che zeos crea i problemi di libreria noti) e le sue query?
Titolo: Re:Campi calcolati
Inserito da: xinyiman - Gennaio 09, 2012, 10:59:07 am
Per fare questo è necessario utilizzare i campi calcolati nel dataset. Immaginiamo la query
Codice: [Seleziona]
 select campo1, campo2 FROM Tabella; 

fare doppio clic sul TSQLQuery e aggiungere un campo calcolato denominato 'prodotto', di tipo galleggiante (non dimenticare di aggiungere i 2 campi esistenti campo1, campo2 se non sono già definiti. Fare clic sul segno + per farli dal fielddefs .). In TSQLQuery.OnCalcFields aggiungere

Codice: [Seleziona]
 SQLQuery1.FieldByName('prodotto').AsFloat:=SQLQuery1.FieldByName('campo1').AsFloat * SQLQuery1.FieldByName('campo2 ').AsFloat 

Fammi sapere se ti funziona!  :)
Titolo: Re:Campi calcolati
Inserito da: orestjump - Gennaio 09, 2012, 04:20:20 pm
Avevo già impostato oncalcfields ma non ricordavo il doppio click sul componente query.
Funziona
Grazie
Titolo: Re:Campi calcolati
Inserito da: xinyiman - Gennaio 09, 2012, 04:29:32 pm
Sono contento!  ;)
Titolo: Re:Campi calcolati
Inserito da: orestjump - Febbraio 03, 2012, 11:40:24 am
Ricordavo che aggiungendo dei campi calcolati ad una tabella, era poi possibile aggiornare modifiche ai campi di tipo data.
Invece l'update di query con campi calcolati tenta di aggiornare anche quest'ultimi e mi segnala errore.
E' normale o bisogna configurare qualcosa?
Titolo: Re:Campi calcolati
Inserito da: xinyiman - Febbraio 03, 2012, 11:48:05 am
non capisco, non avevi risolto con quanto detto sopra?!
Titolo: Re:Campi calcolati
Inserito da: orestjump - Febbraio 03, 2012, 04:33:06 pm
Il refresh del campo funziona bene sia in scroll che in editazione.

L'update su tabella mi segnala errore proprio nel campo calcolato (0.9.30 + Firebird 2.0)
Titolo: Re:Campi calcolati
Inserito da: xinyiman - Febbraio 03, 2012, 04:35:21 pm
ummmmm strano. dovrei fare dei test per capire e verificare. Solo che in questo momento sono preso male. Vediamo se qualche altro utente ci ha già sbattuto il naso!
Titolo: Re:Campi calcolati
Inserito da: xinyiman - Febbraio 03, 2012, 04:52:16 pm
Però una curiosità, a te l'errore te lo rimanda quando aggiorni il campo direttamente dalla DBGrid?! Oppure quando lo aggiorni attraverso altre strade, ad esempio una query sql?!
Titolo: Re:Campi calcolati
Inserito da: orestjump - Febbraio 03, 2012, 05:05:58 pm
Proprio dalla dbgrid
Titolo: Re:Campi calcolati
Inserito da: xinyiman - Febbraio 03, 2012, 05:17:27 pm
moooolto strano, io per le prove che avevo fatto per darti gli altri consigli non avevo questo problema!