[PHP] Recuperare indice per inserirlo in un'altra tabella

Antonio102

Utente Attivo
12 Set 2014
36
0
6
Ciao a tutti, come esercitazione ho creato un piccolo script per la creazione di fatture.

Tramite POST vengono passati i vari dati del cliente, che si trovano nella loro tabella CLIENTI, con index il campo ID.

All'interno di un form, nel quale si possono aggiungere dinamicamente degli input, vengono inseriti i servizi acquistati, quantità, prezzo e aliquota iva. Questi dati vengono salvati in una tabella ITEM, sulla quale non ho inserito nessuna colonna come index. Dovrei inserire un indice? Se sì, cosa?

In una terza tabella FATTURE vengono inseriti idcliente, data, totale fatture, totale imponibile e totale iva.

Quando eseguo lo script nella tabella FATTURE vengono correttamente inseriti i dati richiesti, con la colonna index num che si incremente automaticamente.

Il problema è che vorrei che tale numero venga inserito anche nella colonna id_fattura della tabella ITEM.

Di seguito il codice che utilizzo (so che non è il massimo e si potrebbe sicuramente migliorare), come potrei risolvere il problema?

Grazie in anticipo

PHP:
if(isset($_POST['create'])) {

    $id = $_POST['id']; //id cliente
    $desc = $_POST['servizio']; //descrizione servizio
    $qta = $_POST['quantita']; //quantità servizio
    $prez = $_POST['prezzo']; //prezzo singolo del servizio
    $aliquota = $_POST['iva']; //aliquota iva applicata
    $data = date('Y-m-d', time()); //data corrente
    $tot = 0;
    $tot_imponibile = 0;
    $tot_iva = 0;

    foreach( $desc as $key => $n ) {
        $imponibile = $qta[$key]*$prez[$key];
        $iva = ($imponibile/100)*$aliquota[$key];
        $tot_serv = $imponibile+$iva;
        $tot += $tot_serv; //totale di tutti i servizi acquistati
        $tot_imponibile += $imponibile; //imponibile di tutti i servizi acquistati
        $tot_iva += $iva; //iva di tutti i servizi acquistati

    $query = "INSERT INTO item ";
    $query .= "(id_fattura, servizio, quantita, prezzo, aliquota) VALUES ";
    $query .= "('1','$desc[$key]','$qta[$key]','$prez[$key]','$aliquota[$key]')";

    $insert_query = mysqli_query($connection,$query);

}
    $query = "INSERT INTO fatture ";
    $query .= "(id_cliente, data, totale, imponibile, iva) VALUES ";
    $query .= "('$id','$data','$tot', '$tot_imponibile', '$tot_iva')";

    $bill_query = mysqli_query($connection,$query);

if($insert_query && $bill_query){
    echo "<h1>Dati fattura inseriti correttamente!</h1>";
    echo "<h3>Tra 3 secondi verrai reindirizzato alla homepage</h3>";
    //header("refresh:3; url= ../index.php");
}
else echo "ERRORE: Dati fattura non inseriti<br>" . mysqli_error($connection);
}
 
@Antonio102
Da regolamento del forum e della sezione sei tenuto come tutti noi a mettere un titolo decrittivo della discussione che apri
Solo [ PHP] non va bene Pertanto ti prego di correggere il titolo della tua discussione e leggere attentamente il regolamento.

La prossima volta chiudo la discussione
Grazie
 
seguo la logica del tuo script,
1a soluzione, fai un ciclo foreach, calcoli solo i totali, inserisci la fattura, inserisci gli item con id della fattura
2a soluzione, inserisci fattura, inserisci gli item con id della fattura, fai un update dei totali nel record fattura
 
  • Like
Reactions: Antonio102
seguo la logica del tuo script,
1a soluzione, fai un ciclo foreach, calcoli solo i totali, inserisci la fattura, inserisci gli item con id della fattura
2a soluzione, inserisci fattura, inserisci gli item con id della fattura, fai un update dei totali nel record fattura

Credo che proverò la prima soluzione.

Come indice per la tabella ITEM cosa mi consigli?
 
Come indice per la tabella ITEM cosa mi consigli?
io diffido sempre degli ID automatici,
per la fattura userei il numero di fattura come indice, superando il quesito che hai posto,
per il dettaglio (item) userei il numero di fattura come indice primario ed un contarighe giusto per l'ordinamento e per la gestione di possibili movimenti successivi, vedi note di credito/debito
con questa gestione non ti servono ID
 

Discussioni simili