Torna indietro   Hardware Upgrade Forum > Software > Programmazione

GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo
GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo
Il Gigabyte Gaming A16 offre un buon equilibrio tra prestazioni e prezzo: con Core i7-13620H e RTX 5060 Laptop garantisce gaming fluido in Full HD/1440p e supporto DLSS 4. Display 165 Hz reattivo, buona autonomia e raffreddamento efficace; peccano però le USB e la qualità cromatica del pannello. Prezzo: circa 1200€.
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
C'è tanta sostanza nel nuovo smartphone della Mela dedicato ai creator digitali. Nuovo telaio in alluminio, sistema di raffreddamento vapor chamber e tre fotocamere da 48 megapixel: non è un semplice smartphone, ma uno studio di produzione digitale on-the-go
Intel Panther Lake: i processori per i notebook del 2026
Intel Panther Lake: i processori per i notebook del 2026
Panther Lake è il nome in codice della prossima generazione di processori Intel Core Ultra, che vedremo al debutto da inizio 2026 nei notebook e nei sistemi desktop più compatti. Nuovi core, nuove GPU e soprattutto una struttura a tile che vede per la prima volta l'utilizzo della tecnologia produttiva Intel 18A: tanta potenza in più, ma senza perdere in efficienza
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 06-08-2006, 18:04   #1
anonimizzato
 
Messaggi: n/a
[PHP] update multipli

Ciao a tutti,

ho un problema concettuale sugli update multipli.

Mettiamo che io abbia una tabella ("prodotti") a DB con tot campi, per il momento solo 3:

prodotto_id
prodotto_nome
prodotto_visibile.

il primo è ovviamente l'ID del prodotto il secondo il nome mentre il terzo è un FLAG (1/0) sulla visibilità o meno sul sito ("fittizio") del prodotto stesso che gestisco con un checkbox spuntato o meno.

Ho imparato come gestire gli update multipli creando i "name" dei vari campi come se fossero degli indici di un array.

Quando visualizzo i campi metto infatti.

<input type="text" name="prodotto_nome[<?php echo prodotto_id]" ?> value="" />

e

<input type="checkbox" name="prodotto_visibile[<?php echo prodotto_id]" ?> value="1" />

questo mi permette ovviamente di effettuare per ogni array, cioè per ogni tipologia di campo un ciclo che mi modifica i dati dopo un submit.

IL PUNTO:
Ogni array è però separato in un ciclo "foreach", è un metodo corretto oppure esiste una soluzione più elegante e più pratica che consenta di eseguire un unico grande ciclo?

Spero di essermi spiegato.

Di seguito riporto il codice PHP per gli update implementato sin ora.
Codice PHP:
if(isset($_POST["modifica"])){
    
    
        
// UPDATE VISIBILITA'
        
$sql "update prodotti set prodotto_visibile = 0";
        
mysql_query($sql);
    
        if(
is_array($prodotto_visibile)){
        
           foreach(
$prodotto_visibile as $key => $visibile){
                                                   
                
$sql "update prodotti set prodotto_visibile = 1 where prodotto_id = '".$key."'";
                
mysql_query($sql);
                    
           }
                                                
        } 
        
        
        
// UPDATE NOME
        
foreach($prodotto_nome as $key => $nome){
           
            if(
$nome != ""){                                        
               
$sql "update prodotti set prodotto_nome = '".$nome."' where prodotto_id = '".$key."'";
               
mysql_query($sql);
            } 
                    
       }
        
    } 
  Rispondi citando il messaggio o parte di esso
Old 06-08-2006, 19:44   #2
Xalexalex
Senior Member
 
L'Avatar di Xalexalex
 
Iscritto dal: Jan 2006
Città: Pisa
Messaggi: 2498
Non so se si possa, ma prova a mettere ogni campo come [nome_prodotto][id]...[prodotto_visibile][id] etc..
E poi indenti i due cicli foreach.
Ciaozz
__________________
Xalexalex è offline   Rispondi citando il messaggio o parte di esso
Old 07-08-2006, 10:17   #3
anonimizzato
 
Messaggi: n/a
Oddio non ho capito benissimo, potresti mettere due righe di esempio?

Ciò vorrebbe comunque dire eseguire sempre delle query di update distinte giusto?

Non è possibile fare una query unica che setti subito i valori dei vari array in un unico ciclo?

Grazie per la risposta.
  Rispondi citando il messaggio o parte di esso
Old 07-08-2006, 10:25   #4
Xalexalex
Senior Member
 
L'Avatar di Xalexalex
 
Iscritto dal: Jan 2006
Città: Pisa
Messaggi: 2498
Se hai modo allega le due pagine, oppure mandale per mail a alessandro.xalexalex@gmail.com e te le modifico, spiegarlo a parole mi riesce un po' difficile...
Ciao
Alex
__________________
Xalexalex è offline   Rispondi citando il messaggio o parte di esso
Old 07-08-2006, 10:46   #5
anonimizzato
 
Messaggi: n/a
Guarda avevo postato la stessa richiesta su html.it e mi hanno risposto con una soluzione adatta.

Praticamente faccio un matrice per i valori dei campi così recupero tutto in un unico ciclo foreach e stampo i valori leggendoli dagli ulteriori array annidati 'prodotto_nome' e 'prodotto_visibile'.

Codice PHP:
<input type="text" name="array[<?php echo prodotto_id?>]['prodotto_nome']" value="" />
<input type="text" name="array[<?php echo prodotto_id?>]['prodotto_visibile']" value="" />
Credo fosse la stessa cosa che mi avevi suggerito, comunque grazie.

Cmq tenetevi pronti perchè prima o poi torno.
  Rispondi citando il messaggio o parte di esso
Old 07-08-2006, 10:48   #6
anonimizzato
 
Messaggi: n/a
il PHP è questo:

Codice PHP:
if(isset($_POST["modifica"])){
    
    
                foreach(
$prodotto as $key => $valore){ 
                                                              
                        
$sql "update prodotti set prodotto_nome = '".$valore['prodotto_nome']."', prodotto_visibile = '".$valore['prodotto_visibile']."' where prodotto_id = '".$key."'";
                        
mysql_query($sql);
                
                }                                                            
        
        
    } 
  Rispondi citando il messaggio o parte di esso
Old 07-08-2006, 11:05   #7
Xalexalex
Senior Member
 
L'Avatar di Xalexalex
 
Iscritto dal: Jan 2006
Città: Pisa
Messaggi: 2498
Quote:
Originariamente inviato da Sgurbat
Guarda avevo postato la stessa richiesta su html.it e mi hanno risposto con una soluzione adatta.

Praticamente faccio un matrice per i valori dei campi così recupero tutto in un unico ciclo foreach e stampo i valori leggendoli dagli ulteriori array annidati 'prodotto_nome' e 'prodotto_visibile'.

Codice PHP:
<input type="text" name="array[<?php echo prodotto_id?>]['prodotto_nome']" value="" />
<input type="text" name="array[<?php echo prodotto_id?>]['prodotto_visibile']" value="" />
Credo fosse la stessa cosa che mi avevi suggerito, comunque grazie.

Cmq tenetevi pronti perchè prima o poi torno.
Come hai osaatoooo!!!! Si cmq era +o- quello che dicevo io.
Ciaozz
__________________
Xalexalex è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Lapt...
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile iPhone 17 Pro: più di uno smartphone. &Eg...
Intel Panther Lake: i processori per i notebook del 2026 Intel Panther Lake: i processori per i notebook ...
Intel Xeon 6+: è tempo di Clearwater Forest Intel Xeon 6+: è tempo di Clearwater Fore...
4K a 160Hz o Full HD a 320Hz? Titan Army P2712V, a un prezzo molto basso 4K a 160Hz o Full HD a 320Hz? Titan Army P2712V,...
Start Cup Puglia 2025: il 16 ottobre la ...
Incentivi auto elettriche, falsa partenz...
Silence crea anche in Francia una rete d...
La realtà mista al servizio degli...
Nothing ha un altro smartphone in progra...
Decisione storica ad Amburgo: i cittadin...
Questo è il nuovo motore elettric...
HUAWEI WATCH GT 6: lo smartwatch 'infini...
Fotografia con AI: ecco Caira, la macchi...
PlayStation 6 vs Xbox Magnus: il rumor s...
DJI Osmo Action 4 a soli 208€ su Amazon:...
Irion, la data governance diventa strate...
EHang VT35: debutta in Cina il nuovo aer...
Cooler Master MasterLiquid Atmos II 360:...
Trapela in rete la roadmap dei nuovi gio...
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: 17:54.


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