I have set an example with 2 images (2 input fields) and 1 pdf file at the same time
So, I assume that you will have all the file inputs in your HTML markup, something like this:
<input type="file" name="PDF">
<input type="file" name="MainImage">
<input type="file" name="SecondImage[]">
In this case, to insert the file path of the uploaded file to the database, something like this should work:
$uploadMainTo = null;
if(isset($_FILES['MainImage'])){
$main_image_name = $_FILES['MainImage']['name'];
$main_image_size = $_FILES['MainImage']['size'];
$main_image_tmp = $_FILES['MainImage']['tmp_name'];
$uploadMainTo = $uploadLocation.$main_image_name;
$moveMain = move_uploaded_file($main_image_tmp,$uploadMainTo);
}
$uploadSecondTo = array();
if(count(array_filter($_FILES['SecondImage']))>0){
foreach(array_filter($_FILES['SecondImage']) as $value){
$second_image_name = $value['name'];
$second_image_size = $value['size'];
$second_image_tmp = $value['tmp_name'];
$uploadSecondTo[] = $uploadLocation.$second_image_name;
$moveSecond = move_uploaded_file($second_image_tmp,$uploadSecondTo);
}
$uploadSecondTo = implode(',',$uploadSecondTo);
}
$uploadPdfTo = null;
if(isset($_FILES['PDF'])){
$pdf_name = $_FILES['PDF']['name'];
$pdf_size = $_FILES['PDF']['size'];
$pdf_tmp = $_FILES['PDF']['tmp_name'];
$uploadPdfTo = $uploadLocation.$pdf_name;
$movepdf = move_uploaded_file($pdf_tmp,$uploadPdfTo);
}
$query = $db->execute("INSERT INTO users (pdf, main_image, second_image) VALUES (?,?,?) WHERE ID = ?", array($uploadPdfTo, $uploadMainTo, $uploadSecondTo, $user_id) );
I'm just not sure if i have to initialize the $uploadXTo variables with null or 'NULL'. If you have problems please test this way.
NB Don't forget to use enctype="multipart/form-data" on your form
Hope this will help you