|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
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(); "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
|
|
|
|
|
|
#2 |
|
Senior Member
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? |
|
|
|
|
|
#3 | |
|
Senior Member
Iscritto dal: Sep 2004
Messaggi: 3967
|
Quote:
Infatti se eseguo un 'normale' MySqlCommand.ExecuteNonQuery() funziona.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
|
|
|
|
|
|
|
#4 |
|
Senior Member
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 |
|
|
|
|
|
#5 | |
|
Senior Member
Iscritto dal: Mar 2006
Città: Genova
Messaggi: 2457
|
Quote:
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 |
|
|
|
|
|
|
#6 | |
|
Senior Member
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
|
Quote:
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. |
|
|
|
|
|
|
#7 | |
|
Senior Member
Iscritto dal: Mar 2006
Città: Genova
Messaggi: 2457
|
Quote:
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 |
|
|
|
|
|
|
#8 |
|
Senior Member
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
|
|
|
|
|
|
|
#9 | |
|
Senior Member
Iscritto dal: Mar 2006
Città: Genova
Messaggi: 2457
|
Quote:
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 |
|
|
|
|
|
|
#10 | |
|
Senior Member
Iscritto dal: Sep 2004
Messaggi: 3967
|
Quote:
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
|
|
|
|
|
|
|
#11 | |
|
Senior Member
Iscritto dal: Mar 2006
Città: Genova
Messaggi: 2457
|
Quote:
__________________
tag XBOX live Aldair74 Nick PSNRiordian Affari conclusi con: Anf3t4m1n Krocca magomagnani amoredipippa mone_82 raszagale bizzy89 Andrew_db |
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 10:10.





















