Torna indietro   Hardware Upgrade Forum > Software > Programmazione

WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
Con Midnight, Blizzard tenta il colpaccio: il player housing sbarca finalmente su Azeroth insieme a una Quel'Thalas ricostruita da zero. Tra il dramma della famiglia Ventolesto e il nuovo Prey System, ecco com'è la nuova espansione di World of Warcraft
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 07-06-2008, 11:57   #1
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
[C#]Liste ed Array

Ciao a tutti

vorrei se possibile il vostro aiuto su quanto segue:

Ho una classe Scheda, composta da:

Codice:
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:

Codice:
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
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 07-06-2008, 13:01   #2
Einstein
Senior Member
 
L'Avatar di Einstein
 
Iscritto dal: Jan 2000
Città: Provincia di Parma
Messaggi: 724
Quote:
Originariamente inviato da RaouL_BennetH Guarda i messaggi
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.
Quote:
Originariamente inviato da RaouL_BennetH Guarda i messaggi
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:
Codice:
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:
Codice:
SqlCommand cmdScheda = new SqlCommand();
cmdScheda.Parameters = GetSchedaParameters();
Ciao
__________________
My Pc: Case Enermax Chakra - PSU Corsair HX520 - Gigabyte P35-DS3R - Core2 Duo E6550 - 6 Gb RAM Geil PC800 - 2x WD Caviar SE 320Gb (Raid1) - Xfx GeForce 8600Gt - Master Pioneer DVR111D - Samsung SM T220 - S.O. Windows 7 Ultimate x64 SP1
My blog: http://blogs.ugidotnet.org/alby
Einstein è offline   Rispondi citando il messaggio o parte di esso
Old 07-06-2008, 13:46   #3
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Grazie per la risposta

Ma ho un dubbio:

supponendo che io abbia bisogno di 30 parametri, con la collection dovrei fare:

Codice:
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?
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 07-06-2008, 13:56   #4
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
Quote:
Originariamente inviato da RaouL_BennetH Guarda i messaggi
Grazie per la risposta

Ma ho un dubbio:

supponendo che io abbia bisogno di 30 parametri, con la collection dovrei fare:

Codice:
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.. ), potresti fare le seguenti cose per migliorare il codice:
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:
Codice:
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 }
};
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 07-06-2008, 13:59   #5
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
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
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 07-06-2008, 14:02   #6
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
Quote:
Originariamente inviato da RaouL_BennetH Guarda i messaggi
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

mai usato quell'oggetto..
e ora sono col leopardo e mi rompo ad avviare la VM per fare partire visual studio
prova a vedere su msdn...
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 07-06-2008, 14:15   #7
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
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[] ?!?
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
"Quasi sociopatico": Sam Altma...
Star Wars Eclipse in difficoltà: ...
Gestione del team e romance organiche: l...
Intel lancia Core Ultra X9 378H: hardwar...
Tomodachi Life non supporterà Handheld M...
Identificati i boss di REvil e GandCrab:...
Google Chrome 148 introduce il caricamen...
Tomb Raider: Legacy of Atlantis, l'uscit...
Casa Bianca: proposto un budget ridotto ...
Telecamere Arlo in offerta su Amazon: Es...
Maine primo stato USA a vietare i data c...
DDL PMI, stop alle false recensioni: le ...
Classifiche JustWatch marzo: Una battagl...
iPhone Fold a rischio ritardo: problemi ...
Artemis II: raggiunto il punto più...
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: 14:24.


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