[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);
}
 

Max 1

Super Moderatore
Membro dello Staff
SUPER MOD
MOD
29 Feb 2012
4.439
338
83
@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
 

marino51

Utente Attivo
28 Feb 2013
3.123
200
63
Lombardia
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

Antonio102

Utente Attivo
12 Set 2014
36
0
6
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?
 

marino51

Utente Attivo
28 Feb 2013
3.123
200
63
Lombardia
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
Autore Titolo Forum Risposte Data
M [PHP] Recuperare coppia con valori i valori MAX e coppia con valori MIN PHP 26
B [PHP] recuperare IP dei server in load balancing [RISOLTO] PHP 3
S [PHP] recuperare determinato elemento con lo scraping PHP 1
P [PHP] Recuperare dati da una <select> PHP 4
S [PHP] recuperare dato da una tabella PHP 4
N [PHP] recuperare dati da db PHP 4
A [RISOLTO]Recuperare dati inviati con json tramite php PHP 4
F Recuperare dati json con php PHP 2
F Recuperare una stringa in formato json con php PHP 0
Metazoo Recuperare variabile php da javascript senza aggiornare pagina PHP 5
S [PHP] Recuperare dato esatto tabella PHP 16
J Recuperare variabili da php a java Javascript 2
V Recuperare dati utente joomla 3 in file php esterno Joomla 0
D [php/ios] Recuperare dati da targa auto PHP 0
G phpmailer e php 8.1 con estensione mysqli PHP 5
M Invio dati database via email php PHP 0
K [php] Problema con inner join PHP 4
K [php]form invio dati PHP 0
P Codifica caratteri speciali mysql php PHP 0
K [PHP] Problema con variabili concatenate. PHP 1
E Stampante termica escpos-php PHP 6
JeiMax Modifica codice php personalizzato PHP 2
G Come modificare un pdf in php PHP 1
U Link a doppio file PHP PHP 0
E PHP & jQuery PHP 8
N Passare array da php a javascript PHP 5
F Applicazione PHP/MySQL per prenotazioni: limitare il numero massimo di posti prenotabili PHP 20
L tipo boolean non funzionante su mariadb (mysql). E codice php 7.4. PHP 0
U PHP creare un file excel dopo ricerca nel DB PHP 0
M PHP/MySQL - Estrarre valori min e max di ogni gruppo PHP 5
F Php e fatturazione elettronica PHP 0
P lanciare script asp (o php) da jquery Javascript 1
Couting95 inserire dati da un file di testo in una tabella in php PHP 1
P Data scraping in PHP non funziona PHP 4
C Calcoli matematici in php PHP 5
F Scrivere dei dati in word con php PHP 0
D PHP leggere cartella di Windows PHP 1
I dominio aruba versione php server linux Domini 3
G Colorare menu select attraverso ricerca php PHP 0
L PHP motore di ricerca nel sito PHP 1
S PHP e Mysqli PHP 0
Y Stampare da php su un foglio A6 attraverso una stampante esterna PHP 1
M Visulizzare immagine con php PHP 8
G [PHP] Creare script di prenotazione con controllo disponibilità. PHP 7
G leggere file txt e stampare con php il contenuto a video PHP 7
F Ricreare struttura php+mysql su Xampp Apache 0
Z PHP.INI - STMP per invio email con PHP Server Dedicati e VPS 0
M Array associativi php su 2 campi mysql PHP 10
G Invio form con PHP PHP 3
T fatture con voci fattura in php PHP 0

Discussioni simili