Torna indietro   Hardware Upgrade Forum > Software > Programmazione

PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è
La PNY GeForce RTX 5080 Slim OC si distingue nel panorama delle GPU di fascia alta per il design compatto a due slot, ispirato alla NVIDIA GeForce RTX 5080 Founders Edition. In questo test analizziamo comportamento termico e prestazioni in gioco, valutando se il formato ridotto comprometta o meno l'esperienza complessiva rispetto alle soluzioni più ingombranti presenti sul mercato.
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
HUAWEI WiFi Mesh X3 Pro Suite è probabilmente il router mesh più fotogenico che si possa acquistare oggi in Italia, ma dietro il guscio in acrilico trasparente e le luci LED dinamiche c'è una macchina tecnica costruita attorno allo standard Wi-Fi 7, con velocità teoriche Dual-Band fino a 3,6 Gbps e una copertura fino a 120 m² una volta abbinato il router principale all'extender incluso nel kit
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte
Abbiamo provato le nuove CPU Intel Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: più core e ottimizzazioni al funzionamento interno migliorano le prestazioni, anche in virtù di prezzi annunciati interessanti. A questo si aggiungono nuove ottimizzazioni software. Purtroppo, a fronte di prestazioni di calcolo elevate, il quadro rimane incerto nel gaming, dove l'andamento rimane altalenante. Infine, rimane il problema della piattaforma a fine vita.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-12-2007, 11:49   #1
yagamiraito
Registered User
 
Iscritto dal: Nov 2007
Città: Firenze
Messaggi: 15
[C#] Database & Select

Sto provando a recuperare valori di un Database da C#.

Mi sono venuti un po' di dubbi sul modo in cui ho fatto il tutto.


Codice:
        public string selezionaNome()
        {
            SQLiteConnection connessione;
            SQLiteDataAdapter dataadapter;
            DataSet dataset = new DataSet();

            using (connessione = new SQLiteConnection())
            {
                try
                {
                    
                    connessione.Open();
                    using (dataadapter = new SQLiteDataAdapter("SELECT Nome FROM Persone", connessione))
                    {
                        dataadapter.Fill(dataset, "Nomi");
                    }
                }
                catch (Exception e) { MessageBox.Show(e.ToString()); }
            }
            string nome = null;
            foreach (DataTable dt in dataset.Tables)
            {
                foreach (DataRow dr in dt.Rows)
                {
                    foreach (DataColumn dc in dt.Columns)
                    {
                        nome = (string)dr["nome"];
                    }
                }
            }
            return nome;
        }
Considerando che c'è solo una riga nel database
mi sembra un po' troppo contorto/scorretto fare così per recuperare un solo valore anche se funzionante.
Esiste un modo migliore?
yagamiraito è offline   Rispondi citando il messaggio o parte di esso
Old 19-12-2007, 12:38   #2
0rph3n
Senior Member
 
L'Avatar di 0rph3n
 
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
se devi solamente recuperare dati usa un datareader invece di un dataadapter che riempie un dataset o una datatable

'iao
0rph3n è offline   Rispondi citando il messaggio o parte di esso
Old 19-12-2007, 16:39   #3
yagamiraito
Registered User
 
Iscritto dal: Nov 2007
Città: Firenze
Messaggi: 15
Quote:
Originariamente inviato da 0rph3n Guarda i messaggi
se devi solamente recuperare dati usa un datareader invece di un dataadapter che riempie un dataset o una datatable

'iao
Utilizzando datareader è decisamente più veloce

---


Se invece dovessi restituire un insieme di righe è corretto/efficace restituire un ArrayList??


Codice:
public ArrayList elencaPersone()
        {
            ArrayList elencopersone = new ArrayList();
            SQLiteConnection connessione;
            SQLiteCommand command;
            SQLiteDataReader datareader;



            string nome = null;
            string cognome = null;

            
            using (connessione = new SQLiteConnection())
            {
                try
                {
                    connessione.ConnectionString = ConnessioneDatabase.DBSOURCE;
                    connessione.Open();
                    using (command = new SQLiteCommand( "SELECT * FROM PERSONE,connessione))
                    {
                        using (datareader = command.ExecuteReader())
                        { 
                            if(datareader.HasRows)
                                while (datareader.Read())
                                { 
                                   nome = datareader.GetString(datareader.GetOrdinal("NOME"));
                                   cognome = datareader.GetString(datareader.GetOrdinal("COGNOME"));
                                                 Persona c = new Persona(nome,cognome);
                             elencopersone.Add(c);

                                   
                                }
                        }
                    }
                }
                catch (Exception e) { MessageBox.Show(e.ToString()); }
            }
                return elencopersone;
        }
yagamiraito è offline   Rispondi citando il messaggio o parte di esso
Old 19-12-2007, 17:30   #4
0rph3n
Senior Member
 
L'Avatar di 0rph3n
 
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
vara, ti dico come io di solito imposto la questione (e di sicuro ci sono modi migliori ):

ho una sola classe che interagisce con il database occupandosi di connection, command e via dicendo ed espone i metodi essenziali ad esempio
  • public DataReader Seleziona (string statement, ParameterCollection parametri)
  • public int Aggiorna (string statement, ParameterCollection parametri)
  • ...
poi ho n classi che si appoggiano su questa e che sono legate ad una specifica "entità".

ad esempio avrò una classe UtenteDALC (DALC sta per Data Access Logic Component) che esporrà (sempre ad esempio) il metodo
  • public LinkedList<UtenteBE> Recupera (VincoliSelezioneUtente vincoli)
che si occuperà _in base ai vincoli specificati nell'oggetto VincoliSelezioneUtente_ di comporre la query, di creare i parametri _sempre in base ai vincoli specificati nell'oggetto VincoliSelezioneUtente_ e di inserirli nella collection per poi darli in pasto al metodo Seleziona della classe che interagisce con il db.
Fatto questo, con i dati che legge dal DataReader restituitogli istanzia tanti oggetti UtenteBE quanti sono i record risultanti dalla query e li inserisce nella LinkedList che restituirà al suo chiamante.

In questo modo separi il livello che si occupa dell'accesso ai dati da tutto il resto del sistema.
Per questo mi sembra abbastanza flessibile e inoltre la maggior parte del codice che scrivi è riutilizzabile.
0rph3n è offline   Rispondi citando il messaggio o parte di esso
Old 29-12-2007, 19:51   #5
feal87
Junior Member
 
Iscritto dal: Dec 2007
Messaggi: 2
Il concetto esposto da 0rph3n è stato fra l'altro esposto e materializzato da Microsoft nel LINQ attualmente utilizzabile nell'ultima versione del framework.
Prova a darci un occhiata, è una vera rivoluzione in questo senso.
feal87 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è PNY RTX 5080 Slim OC, sembra una Founders Editio...
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei Wi-Fi 7 con il design di una vetta innevata: ecc...
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte Core Ultra 7 270K Plus e Core Ultra 7 250K Plus:...
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu PC Specialist Lafité 14 AI AMD: assemblat...
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto Recensione Nothing Phone 4(a): sempre iconico ma...
L'AI agentica potrebbe trasformare Inter...
Qualcomm lancerà due chip per sma...
Xiaomi dà i numeri: ecco come &eg...
AMD annuncia Ryzen 9 9950X3D2 Dual Editi...
CyrusOne avvia la costruzione del suo pr...
Cloud in crescita, ma l’adozione dell’IA...
OpenAI cancella l'adult mode di ChatGPT:...
Google Search Live arriva in Italia: la ...
MacBook Air 15'' con chip M4 (2025) crol...
Ora è possibile trasferire file t...
Apple domina con il MacBook Neo: i lapto...
Arriva la nuova gamma di PC Dell Pro per...
DJI Avata 360: la recensione del primo d...
Il browser di Samsung arriva su Windows,...
I satelliti AI Sat Mini per i datacenter...
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: 02:18.


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