View Full Version : [C#]Liste ed Array
RaouL_BennetH
07-06-2008, 11:57
Ciao a tutti :)
vorrei se possibile il vostro aiuto su quanto segue:
Ho una classe Scheda, composta da:
public class Scheda
{
private int id;
private double valore;
private DateTime tempo;
public int ID
{
get
{
return id;
}
set
{
id = value;
}
}
//blabla per gli altri 2
}
Poi, ho un'altra classe DBScheda che eredita da Scheda:
public class DBScheda : Scheda
{
public SqlParameter[] GetSchedaParameters()
{
SqlParameter[] p = new SqlParameter[4];
p[0] = new SqlParameter("@id", SqlDbType.Int32, 6);
p[0].Value = ID;
//blabla
return p;
}
}
Ora, le mie domande sono:
1) Non ho capito come fare se volessi inserire GetSchedaParameters()
un try/catch, nel senso non so cosa far ritornare al catch
2) Mi hanno fortemente sconsigliato di utilizzare quest'approccio
e di utilizzare le liste, ma sulle guide non ho capito molto sinceramente...
Mi dareste una manina?
Grazie. RaouL :)
Einstein
07-06-2008, 13:01
1) Non ho capito come fare se volessi inserire GetSchedaParameters()
un try/catch, nel senso non so cosa far ritornare al catch
In un blocco di codice simile, così a naso non saprei in quale caso possa verificarsi un eccezione, quindi non inserirei nessun try/catch.
2) Mi hanno fortemente sconsigliato di utilizzare quest'approccio
e di utilizzare le liste, ma sulle guide non ho capito molto sinceramente...
Se il tuo scopo è quello di usare l'output della funzione GetSchedaParameter() per costruire un SqlCommand, forse è meglio farle restituire una SqlParameterCollection:
public SqlParameterCollection GetSchedaParameters()
{
SqlParameterCollection result = new SqlParameterCollection();
SqlParameter p1 = new SqlParameter("@id", SqlDbType.Int32, 6)
p1.Value = ID;
result.Add(p1);
// blabla
return result;
}
Poi, nel codice:
SqlCommand cmdScheda = new SqlCommand();
cmdScheda.Parameters = GetSchedaParameters();
Ciao
RaouL_BennetH
07-06-2008, 13:46
Grazie per la risposta :)
Ma ho un dubbio:
supponendo che io abbia bisogno di 30 parametri, con la collection dovrei fare:
SqlParameterCollection c = new SqlParameterCollection();
SqlParameter p1 = new blabla
p1.Value = asdads
c.Add(p1);
SqlParameter p2 = new asdasdasd
p2.Value = 12
c.Add(p2);
////
Cioè, alla collection devo aggiungere un parametro per volta?
^TiGeRShArK^
07-06-2008, 13:56
Grazie per la risposta :)
Ma ho un dubbio:
supponendo che io abbia bisogno di 30 parametri, con la collection dovrei fare:
SqlParameterCollection c = new SqlParameterCollection();
SqlParameter p1 = new blabla
p1.Value = asdads
c.Add(p1);
SqlParameter p2 = new asdasdasd
p2.Value = 12
c.Add(p2);
////
Cioè, alla collection devo aggiungere un parametro per volta?
se utilizzi .net 3 (o 3.5... non mi ricordo mai.. :muro: ), potresti fare le seguenti cose per migliorare il codice:
public class Scheda
{
public int ID { get; set; }
public double Valore { get; set; }
public DateTime Tempo { get; set; }
}
mentre invece per quanto riguarda la collection:
SqlParameterCollection c = new SqlParameterCollection() {
new SqlParameter() { ID = 1, Value = "asdasd", Tempo = xxx },
new SqlParameter() { ID = 2, Value = "asasd", Tempo = xx },
new SqlParameter() { ID = 3, Value = "asdasd", Tempo = xxx },
.........
new SqlParameter() { ID = N, Value = "asdasd", Tempo = xxx }
};
RaouL_BennetH
07-06-2008, 13:59
eh no, la versione che uso è 2.0.
Comunque sia, c'è qualcosa che non va:
SqlParameterCollection c = new SqlParameterCollection();
blablabla
non compila:
SqlParameterCollection has no constructors defined
^TiGeRShArK^
07-06-2008, 14:02
eh no, la versione che uso è 2.0.
Comunque sia, c'è qualcosa che non va:
SqlParameterCollection c = new SqlParameterCollection();
blablabla
non compila:
SqlParameterCollection has no constructors defined
:boh:
mai usato quell'oggetto..
e ora sono col leopardo e mi rompo ad avviare la VM per fare partire visual studio :p
prova a vedere su msdn...
RaouL_BennetH
07-06-2008, 14:15
Boh, da qualsiasi link:
"Un oggetto SqlParameterCollection non può essere istanziato da solo, ma solo da un oggetto di tipo SqlCommand"
E fa l'esempio:
SqlCommand cmd = new SqlCommand(stringa, connessione);
cmd.Parameters.Add(collezione)
Ok....
Ma se non posso creare la collezione... che ci aggiungo?
Devo allora riconsiderare:
SqlParameter[] ?!?
vBulletin® v3.6.4, Copyright ©2000-2025, Jelsoft Enterprises Ltd.