Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Polestar 3 Performance, test drive: comodità e potenza possono convivere
Polestar 3 Performance, test drive: comodità e potenza possono convivere
Abbiamo passato diversi giorni alla guida di Polestar 3, usata in tutti i contesti. Come auto di tutti i giorni è comodissima, ma se si libera tutta la potenza è stupefacente
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
In occasione del proprio Architecture Deep Dive 2025 Qualcomm ha mostrato in dettaglio l'architettura della propria prossima generazione di SoC destinati ai notebook Windows for ARM di prossima generazione. Snapdragon X2 Elite si candida, con sistemi in commercio nella prima metà del 2026, a portare nuove soluzioni nel mondo dei notebook sottili con grande autonomia
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
DJI Mini 5 Pro porta nella serie Mini il primo sensore CMOS da 1 pollice, unendo qualità d'immagine professionale alla portabilità estrema tipica di tutti i prodotti della famiglia. È un drone C0, quindi in un peso estremamente contenuto e che non richiede patentino, propone un gimbal rotabile a 225 gradi, rilevamento ostacoli anche notturno e autonomia fino a 36 minuti. Caratteristiche che rendono il nuovo drone un riferimento per creator e appassionati
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


Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026 Qualcomm Snapdragon X2 Elite: l'architettura del...
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice Recensione DJI Mini 5 Pro: il drone C0 ultra-leg...
ASUS Expertbook PM3: il notebook robusto per le aziende ASUS Expertbook PM3: il notebook robusto per le ...
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Pazzesco: Panasonic Lumix DC-GH5M2E a 79...
Ecco tutte le offerte Black Friday pi&ug...
DJI Neo a 169€, Flip Combo a 309€ e molt...
Quattro persone arrestate negli USA per ...
Kindle Paperwhite Signature Edition, Col...
Boom di vendite per Kindle e Fire TV Sti...
iPhone 17 Pro, il più desiderato,...
Nuovo record, 849€ per i MacBook Air con...
Wi-Fi 8 secondo Intel: la nuova era del ...
MediaWorld e il caso degli iPad Air vend...
ESA: rilevati 40 mila asteroidi vicino a...
La batteria salva fabbriche di EQORE ott...
SpaceX Starship: iniziati i test della t...
Datacenter IA nello spazio entro 5 anni,...
Telescopio spaziale James Webb: rilevato...
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: 10:10.


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