Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
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.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 07-11-2007, 10:30   #1
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
[mysql/C#]Non capisco ExecuteScalar()

Ciao a tutti

Non riesco a far funzionare il metodo ExecuteScalar()

in teoria:

Codice:
string select = "SELECT campo FROM tabella WHERE altrocampo = 'valore'";
MySqlCommand cmd = new MySqlCommand(select, miaConnessione);
int result = (int)cmd.ExecuteScalar();
Questo esempio è presente ovunque su internet, ma a me da sempre questo errore su "result":

"Riferimento ad un oggetto non impostato su un'istanza di oggetto"

Chi mi aiuta?

Grazie
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 07-11-2007, 10:54   #2
0rph3n
Senior Member
 
L'Avatar di 0rph3n
 
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
in quelle tre righe di codice non si vede l'inizializzazione di miaConnessione...
...c'è nel codice complessivo?
0rph3n è offline   Rispondi citando il messaggio o parte di esso
Old 07-11-2007, 11:01   #3
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da 0rph3n Guarda i messaggi
in quelle tre righe di codice non si vede l'inizializzazione di miaConnessione...
...c'è nel codice complessivo?
si, la connessione è attiva

Infatti se eseguo un 'normale' MySqlCommand.ExecuteNonQuery() funziona.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 07-11-2007, 11:37   #4
0rph3n
Senior Member
 
L'Avatar di 0rph3n
 
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
Appena fatto un paio di prove.
Ah, prove effettuate con vs 2008 e framework 3, comunque non dovrebbe essere un problema.

Allora, piuttosto che dichiarare come int la variabile a cui assegni il risultato del metodo ExecuteScalar() (ovvero result), dichiarala come object e poi chiamando il metodo getType() controlla il tipo...

...adesso mi bevo un caffettino, a tra poco
0rph3n è offline   Rispondi citando il messaggio o parte di esso
Old 07-11-2007, 11:39   #5
Riordian
Senior Member
 
L'Avatar di Riordian
 
Iscritto dal: Mar 2006
Città: Genova
Messaggi: 2457
Quote:
Originariamente inviato da RaouL_BennetH Guarda i messaggi
Ciao a tutti

Non riesco a far funzionare il metodo ExecuteScalar()

in teoria:

Codice:
string select = "SELECT campo FROM tabella WHERE altrocampo = 'valore'";
MySqlCommand cmd = new MySqlCommand(select, miaConnessione);
int result = (int)cmd.ExecuteScalar();
Questo esempio è presente ovunque su internet, ma a me da sempre questo errore su "result":

"Riferimento ad un oggetto non impostato su un'istanza di oggetto"

Chi mi aiuta?

Grazie
Ho il dubbio che se ricevi un valore null come ritorno il cast a int possa dare dei problemi.
Prova a fare un test come quello sotto e vedere che succede:

Codice:
object result = null;
int tmp;
result = cmd.executeScalar();
if (result!=null)
tmp = (int)result;
__________________
tag XBOX live Aldair74
Nick PSNRiordian
Affari conclusi con: Anf3t4m1n Krocca magomagnani amoredipippa mone_82 raszagale bizzy89 Andrew_db
Riordian è offline   Rispondi citando il messaggio o parte di esso
Old 07-11-2007, 12:08   #6
0rph3n
Senior Member
 
L'Avatar di 0rph3n
 
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
Quote:
Originariamente inviato da Riordian Guarda i messaggi
Ho il dubbio che se ricevi un valore null come ritorno il cast a int possa dare dei problemi.
ExecuteScalar restituisce il valore della prima colonna del primo record di tutto il resultset, o null se il resultset è vuoto.
Ora visto che lui ha fatto un COUNT, perlomeno gli dovrebbe uscire uno 0 (ammesso che non abbia sbagliato la query, ma in questo caso dovrebbe venire generata un'eccezione quindi per forza di cose ExecuteReader() non gli può restituire NULL).

Nella mia prova piccina picciò (eseguito una query con COUNT pure io), ExecuteScalar() restituisce un Int64 (value type) boxato in un'object (reference type).
Quando lui va a fare il cast dall'object (reference type) restituito da ExecuteScalar() in int (value type) salta fuori il problema.
soluzione: prima bisogna unboxare l'Int64 dall'object e poi si può fare il cast a int.
0rph3n è offline   Rispondi citando il messaggio o parte di esso
Old 07-11-2007, 12:11   #7
Riordian
Senior Member
 
L'Avatar di Riordian
 
Iscritto dal: Mar 2006
Città: Genova
Messaggi: 2457
Quote:
Originariamente inviato da 0rph3n Guarda i messaggi
ExecuteScalar restituisce il valore della prima colonna del primo record di tutto il resultset, o null se il resultset è vuoto.
Ora visto che lui ha fatto un COUNT, perlomeno gli dovrebbe uscire uno 0 (ammesso che non abbia sbagliato la query, ma in questo caso dovrebbe venire generata un'eccezione quindi per forza di cose ExecuteReader() non gli può restituire NULL).

Nella mia prova piccina picciò (eseguito una query con COUNT pure io), ExecuteScalar() restituisce un Int64 (value type) boxato in un'object (reference type).
Quando lui va a fare il cast dall'object (reference type) restituito da ExecuteScalar() in int (value type) salta fuori il problema.
soluzione: prima bisogna unboxare l'Int64 dall'object e poi si può fare il cast a int.
Nella query che ha scritto non ha chiesto un count ma ha fatto la select di un campo
Comunque al di la di tutto io la executescalar la uso sempre così, prima metto in un objet e poi faccio il cast
__________________
tag XBOX live Aldair74
Nick PSNRiordian
Affari conclusi con: Anf3t4m1n Krocca magomagnani amoredipippa mone_82 raszagale bizzy89 Andrew_db
Riordian è offline   Rispondi citando il messaggio o parte di esso
Old 07-11-2007, 12:25   #8
0rph3n
Senior Member
 
L'Avatar di 0rph3n
 
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
Quote:
Originariamente inviato da Riordian Guarda i messaggi
Nella query che ha scritto non ha chiesto un count ma ha fatto la select di un campo
le mie solite figure da fagiano
...come chezzo mi è entrato in testa il COUNT?!
0rph3n è offline   Rispondi citando il messaggio o parte di esso
Old 07-11-2007, 12:32   #9
Riordian
Senior Member
 
L'Avatar di Riordian
 
Iscritto dal: Mar 2006
Città: Genova
Messaggi: 2457
Quote:
Originariamente inviato da 0rph3n Guarda i messaggi
le mie solite figure da fagiano
...come chezzo mi è entrato in testa il COUNT?!
a volte capita
Tra l'altro se il problema fosse sul cast a int mi aspetterei un'altro tipo di eccezione, tipo invalidcastexception.
Vedremo che dice
__________________
tag XBOX live Aldair74
Nick PSNRiordian
Affari conclusi con: Anf3t4m1n Krocca magomagnani amoredipippa mone_82 raszagale bizzy89 Andrew_db
Riordian è offline   Rispondi citando il messaggio o parte di esso
Old 07-11-2007, 13:03   #10
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da Riordian Guarda i messaggi
a volte capita
Tra l'altro se il problema fosse sul cast a int mi aspetterei un'altro tipo di eccezione, tipo invalidcastexception.
Vedremo che dice
infatti, il problema non è sul cast, ma avete ragione entrambi.

Se faccio una select normale, executescalar si aspetta di essere gestito come ha indicato Riordian, invece, se faccio un count o un max, funziona come ci si aspetterebbe.

Grazie ad entrambi
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 07-11-2007, 13:19   #11
Riordian
Senior Member
 
L'Avatar di Riordian
 
Iscritto dal: Mar 2006
Città: Genova
Messaggi: 2457
Quote:
Originariamente inviato da RaouL_BennetH Guarda i messaggi
infatti, il problema non è sul cast, ma avete ragione entrambi.

Se faccio una select normale, executescalar si aspetta di essere gestito come ha indicato Riordian, invece, se faccio un count o un max, funziona come ci si aspetterebbe.

Grazie ad entrambi
felice di esserti stato utile
__________________
tag XBOX live Aldair74
Nick PSNRiordian
Affari conclusi con: Anf3t4m1n Krocca magomagnani amoredipippa mone_82 raszagale bizzy89 Andrew_db
Riordian è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
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...
Cyberpunk 2077 in versione PC su smartph...
BYD si gioca un grosso jolly: pronta Rac...
Samsung annuncia l'arrivo in Italia dei ...
Offerta lancio Pixel 10a: come ottenere ...
Google presenta Pixel 10a: poche le novi...
Caos F1 2026: 14 monoposto senza omologa...
Tesla festeggia il primo Cybercab prodot...
Desktop piccolo e potente? NZXT H2 Flow ...
Polestar spinge sull'acceleratore: arriv...
Nuovo record mondiale nel fotovoltaico: ...
L'ultimo baluardo cade: fine supporto pe...
'Il mondo non ha mai visto nulla di simi...
La Commissione europea mette sotto indag...
Arriva il primo computer quantistico ad ...
'Se lavori al PC sei a rischio': la prev...
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: 17:57.


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