Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
Intel Xeon 6+: è tempo di Clearwater Forest
Intel Xeon 6+: è tempo di Clearwater Forest
Intel ha annunciato la prossima generazione di processori Xeon dotati di E-Core, quelli per la massima efficienza energetica e densità di elaborazione. Grazie al processo produttivo Intel 18A, i core passano a un massimo di 288 per ogni socket, con aumento della potenza di calcolo e dell'efficienza complessiva.
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


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,...
Recensione Google Pixel Watch 4: basta sollevarlo e si ha Gemini sempre al polso Recensione Google Pixel Watch 4: basta sollevarl...
Elgato Embrace: una sedia ergonomica pro...
Brad Pitt torna in pista: F1 – Il Film a...
Hitachi Vantara annuncia la sua AI Facto...
Brembo passa all'alluminio riciclato al ...
HONOR pronta a sfidare gli iPad Pro con ...
OpenAI esce allo scoperto: confermati i ...
In arrivo altri due prodotti da Apple en...
Il tool per aggiornare da Windows 10 a W...
Rishi Sunak entra in Microsoft e Anthrop...
Porsche in poche ore chiude la formazion...
iPhone 17 disponibili su Amazon al prezz...
La Ferrari Elettrica non è la cau...
Ricarica da record: Zeekr supera i 1.300...
Un 'capezzolo' con feedback aptico al po...
Porsche Taycan Rush a Misano: prima al v...
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: 23:39.


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