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