Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
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


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Roscosmos ha posticipato (ancora) il lan...
Isar Aerospace si prepara al secondo lan...
Tory Bruno è entrato in Blue Orig...
Fujifilm lancia la cartuccia per archivi...
Dreame H15 Mix: la soluzione 7-in-1 per ...
AirPods Pro 3 in forte sconto su Amazon:...
36 offerte Amazon, molte appena partite:...
2 caricatori multipli eccezionali: da 28...
OLED e 360 Hz a un prezzo senza preceden...
Roborock Q10 S5+ a un prezzo molto conve...
Upgrade PC a prezzo ridotto: le migliori...
Sono i 6 smartphone migliori su Amazon: ...
Google Pixel 9a a 361€, mai così ...
Super sconti sugli spazzolini Oral-B, an...
Aspira a 6000Pa, lava bene, costa 139€: ...
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: 05:51.


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