Ciao a tutti,
ho un modulo con alcuni campi input di testo che invia tutti i valori dei campi (anche quelli nulli) ad una pagina PHP che sulla base di questi valori aggiorna un record di una tabella di un DB.

Il problema è il seguente:

La stringa SQL deve essere "UPDATE tabella SET campo1=valore1, campo2=valore2, campo3=valore3 WHERE id=stringa"

Il mio form manda quindi alla pagina php i 3 valori (valore1, valore2, valore3) che io pesco con $_GET e assegno a 3 variabili.

Devo fare in modo che se l'utente non inserisce un valore in uno o più dei 3 campi, la stringa UPDATE non contenga quel campo da aggiornare perchè altrimenti mi andrebbe a sovrascrivere un valore che invece l'utente non ha deciso di modificare.

Come posso fare?

Ero partito con una cosa del genere

codice:
$stringaSQL = "UPDATE tabella SET ";
if (!is_null($valore1) OR $valore1 != "") {
   $stringaSQL = $stringaSQL . "campo1=" . $valore1 . ", ";
}
if (!is_null($valore2) OR $valore2 != "") {
   $stringaSQL = $stringaSQL . "campo2=" . $valore2 . ", ";
}
if (!is_null($valore3) OR $valore3 != "") {
   $stringaSQL = $stringaSQL . "campo3=" . $valore3 . ", ";
}
$stringaSQL = $stringaSQL . "WHERE id=" . $variabile;
Il problema è che cosi in ogni caso alla fine prima della condizione WHERE mi ritrovo una virgola che darebbe errore.
E poi se nessuno dei campi fosse settato cosa accadrebbe?