Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Per diversi giorni il Galaxy S26 Ultra di Samsung è stato il nostro compagno di vita. Oltre alle conferme del colosso coreano come la qualità del display e una suite AI senza rivali, arriva il Privacy Display, un unicum nel mondo smartphone. Ci sono ancora alcuni gap che non sono riusciti a colmare lato batteria e fotocamera, seppur con alcuni miglioramenti.
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Abbiamo provato per voi il nuovo DLC lanciato a sorpresa da Blizzard per Diablo II: Resurrected e quella che segue è una disamina dei nuovi contenuti che abbiamo avuto modo di sperimentare nel corso delle nostre sessioni di gioco, con particolare riguardo per la nuova classe dello Stregone
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Siamo tornati nel parco tecnologico di Trieste per il kick-off del programma che mette a disposizione di cinque startup le infrastrutture di ricerca, dal sincrotrone Elettra ai laboratori di genomica e HPC. Roberto Pillon racconta il modello e la visione
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-03-2008, 17:51   #1
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
[C#]Ignorare valori nulli all'interno di una griglia

Ciao a tutti

Ho questo problema:

data una classe di esempio:

Codice:
public class SchedaLavori
{
     private string nome;
     private int id;
     public string Nome
     { 
         get { return nome; }
         set { nome = value; }
     }
     public int ID
     {
         get { return id; }
         set { id = value; }
     }
}

//in un form:

SchedaLavori scheda = new SchedaLavori();
scheda.Nome = miaGriglia.Rows[0].Cells[1].Value;
scheda.ID = miaGriglia.Rows[0].Cells[2].Value;
A questo punto, io dovrei dire che se nella cella 2 non c'è nessun valore, l'applicazione se ne deve fregare e andare avanti.

Potrei risolvere con un banale "if", ma dato che devo valutare diverse celle della griglia, mi andrei ad incasinare con una montagna di salti condizionali.

Suggerimenti?

Grazie.

RaouL.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2008, 19:30   #2
xsatellitex
Member
 
L'Avatar di xsatellitex
 
Iscritto dal: Dec 2007
Messaggi: 190
Scusa ma gli if si usano per decidere cosa fare quando si verifica una certa condizione e NON cosa non fare quando si verifica una certa condizione come dici tu.
Altrimenti saresti fritto a usare gli if per qualsiasi cosa che non dovrebbe fare.
Se vuoi che il programma non faccia niente col valore nullo in cella 2 allora non devi fare niente.
Se invece vuoi che il programma faccia qualcosa col valore nullo in cella 2 usa gli if.
O forse ho capito io male.

Ultima modifica di xsatellitex : 17-03-2008 alle 19:34.
xsatellitex è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2008, 23:59   #3
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da xsatellitex Guarda i messaggi
Scusa ma gli if si usano per decidere cosa fare quando si verifica una certa condizione e NON cosa non fare quando si verifica una certa condizione come dici tu.
Altrimenti saresti fritto a usare gli if per qualsiasi cosa che non dovrebbe fare.
Se vuoi che il programma non faccia niente col valore nullo in cella 2 allora non devi fare niente.
Se invece vuoi che il programma faccia qualcosa col valore nullo in cella 2 usa gli if.
O forse ho capito io male.
Eh... magari fosse così semplice....

il fatto è che quando trova un valore nullo nella cella, l'esecuzione si blocca perchè ci sono operazioni matematiche da fare sulle altre celle.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 20-03-2008, 16:13   #4
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
un piccolo up

Il problema è questo in sintesi:

Codice:
private void SaveData(DataGridViewCellEventArgs e)
{
    Scheda s = new Scheda();
    s.ExecutionTime = grid.Rows[e.RowIndex].Cells[1].Value;
    s.Price = grid.Rows[e.RowIndex].Cells[2].Value;
    s.NotWorked = grid.Rows[e.RowIndex].Cells[3].Value;

    //blablabla
    DbClass db = new DbClass();
    db.OpenConnection();
    db.CommandString = "INSERT INTO Jobs(ExecutionTime, Price, NotWorked) " +
        "VALUES('" + s.ExecutionTime + "', '" + s.Price + "', '" + s.NotWorked + "')";
    db.PerformAction();
    db.CloseConnection();
}
Ora, fin quando nelle celle della griglia ci sono valori, va tutto bene, ma se una cella non contiene nulla, il programma si ferma dandomi:

Codice:
Riferimento a un oggetto non impostato su un'istanza di oggetto
Adesso, io ho sintetizzato il numero di celle, ma la griglia ne contiene ben 19.

E mica posso fare un if su ogni caso possibile? (per esempio cella1 e cella3 con valore e tutte le altre senza, cella1, cella2, cella9 con valore etc...)

per favore.....
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 21-03-2008, 10:41   #5
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
E fare una cosa del genere potrebbe essere accettabile?

(faccio finta che s.ExecutionTime sia un double, s.Price una String e s.NotWorked un boolean)

Codice:
private void SaveData(DataGridViewCellEventArgs e)
{
    Scheda s = new Scheda();

    double executionTime = grid.Rows[e.RowIndex].Cells[1].Value;
    String price = grid.Rows[e.RowIndex].Cells[2].Value;
    boolean notWorked = grid.Rows[e.RowIndex].Cells[3].Value;
    // ecc...
    
    s.ExecutionTime = (executionTime != null) ? executionTime  : 0.0;
    s.Price = (price != null) ? price  : "no price";
    s.NotWorked = (notWorked != null) ? notWorked  : false;
    // ecc...

    //blablabla
    DbClass db = new DbClass();
    db.OpenConnection();
    db.CommandString = "INSERT INTO Jobs(ExecutionTime, Price, NotWorked) " +
        "VALUES('" + s.ExecutionTime + "', '" + s.Price + "', '" + s.NotWorked + "')";
    db.PerformAction();
    db.CloseConnection();
}
Ciao, non conoscendo maggiormente i dettagli l'idea che mi è venuta in mente è quella di assegnare un valore di default per ogni tipo di dato qualora la restituzione del valore nella cella corrispondente fosse null/vuoto.

Naturalmente i valori di default devono essere scelti in modo da far funzionare le cose "a valle" anche in presenza di valori nulli nelle celle.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 21-03-2008, 10:44   #6
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Metti caso che riusciamo a risolvere questo problema.
Ma poi, quando l'esecuzione giungerà all'esecuzione p.es. di quell'istruzione SQL, nel caso in cui la cella di ExecutionTime fosse non valorizzata, cosa vorresti accadesse?
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 21-03-2008, 10:48   #7
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
@EDIT: ho detto una cavolata

@RI-EDIT: mi correggo, e riposto il mio sospetto: non è che te vuoi che la stringa SQL venga costruita "dinamicamente" includendo, di volta in volta, solo i campi non nulli?

Ultima modifica di banryu79 : 21-03-2008 alle 10:50. Motivo: sparato la cazzata delle 11 del mattino
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 21-03-2008, 13:08   #8
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Grazie per l'interessamento

In effetti, al problema di che tipo di dato dovesse essere scritto nel db al momento in cui viene rilevata una cella senza valore, non ci avevo proprio pensato

Ad ogni modo, credo di aver risolto utilizzando l'oggetto MySqlParameter abbandonando l'idea dei membri della classe.

Lo sto usando in maniera ancora un pò rozza credo, e mi piacerebbe che magari ci diate un'occhiata per vedere se le mie cavolate sono davvero grosse:

Codice:
MySqlParameter[] p = new MySqlParameter[numeroParametriCheServono];

p[0] = new MySqlParameter("?ExecutionTime", MySqlDbType.Double, 0);
p[0].Value = grid.Rows[x].Cells[0].Value;

//blabla

myDbConnection.CommandString = "INSERT INTO Jobs(ExecutionTime, blabla) " +
"VALUES(?ExecutionTime, ?Price, ?NotWorked)";

//blabla
In questo modo, se non ci sono valori presenti nelle celle, l'esecuzione al momento non si ferma e nel database mi scrive i valori di default che scelgo al momento della dichiarazione ed inizializzazione dell'oggetto MySqlParameter.

Se secondo voi il modo di risolvere il problema può essere adeguato, poi avrei altre domande da farvi

Grazie

RaouL.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 21-03-2008, 22:45   #9
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da RaouL_BennetH Guarda i messaggi
In questo modo, se non ci sono valori presenti nelle celle, l'esecuzione al momento non si ferma e nel database mi scrive i valori di default che scelgo al momento della dichiarazione ed inizializzazione dell'oggetto MySqlParameter.

Se secondo voi il modo di risolvere il problema può essere adeguato, poi avrei altre domande da farvi

Grazie

RaouL.
Pensa che una delle cose che mi erano venute in mente era proprio quella di creare una classe per gestire eventuali valori/oggetti null inizializzandoli al valore di default in base al tipo (alla stregua della jvm) oppure a valori di default 'che hanno senso' per il db con cui si lavora o l'applicazione specifica in base alla logica scelta.

Lo scopo era di utlizzare oggetti di questa classe più o meno come vedo nel tuo post qui sopra con l'istanza della classe MySqlParameter, classe che non conoscevo


L'altra mia ipotesi era basata sulla possibilità che nella tabella "Jobs" del tuo db tutti i campi (bhe, aparte la chiave primaria ovviamente) potessero anche essere NULL (o per meglio dire, non fossero settati a Not Null) in modo da poter eseguire una query "costruita dinamicamente" contenente i soli parametri delle celle non null.
Quindi alcuni campi di una riga avrebbero potuto essere null però comunque "a valle" un eventuale metodo che poi in seguito va a prelevare dei dati da quella tabella per fare dei calcoli avrebbe dovuto affrontare la faccenda dei campi null, magari gestendola durante la restituzione dei valori nel resultSet della query, ergo alla fine tanto vale gestire fin da subito la faccenda.

Ciao
banryu79 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
Spotify introduce 'Taste Profile': il co...
Sole e pioggia insieme: il nuovo pannell...
AWS e Cerebras uniscono le forze: nuova ...
Windows 11: accesso al drive C: bloccato...
BYD pronta a comprare un marchio storico...
Windows 11 si prepara ai monitor oltre i...
Apple avrebbe fissato un target di vendi...
Ultimi giorni per sfruttare le Offerte d...
I migliori smartphone in offerta ora su ...
Le migliori TV delle Offerte di Primaver...
Uno dei robot più avanzati del 2025 crol...
Robot aspirapolvere con stazione automat...
Il nuovo top di gamma compatto di OPPO n...
Nilox aggiorna la sua gamma di fat e-bik...
Meta valuta tagli fino al 20% della forz...
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: 21:25.


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