PDA

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[] ?!?