How do I insert simultaneously insert multiple checkbox values and filenames using PHP into MySQL DB

Hi,

I am trying to insert an new row for each element in a checkbox array.  Multiple file uploads are submitted via the same form and these filenames are being written to the database at the same time.  

While I've been able to write both the filenames and the checkbox values to the DB  I'm still having issues with the loop itself and with the checkbox values being inserted more than once.

Hope the above makes sense!

<!-- FORM SAMPLE -->
 
<input type="checkbox" name="language[]" value="en" />EN
<input type="checkbox" name="language[]" value="de" />DE
<input type="checkbox" name="language[]" value="fr" />FR
 
<!-- The file upload fields only display after selecting the relevant checkbox -->
 
<input name="files[]" type="file" />File EN
<input name="files[]" type="file" />File DE
<input name="files[]" type="file" />File FR
 
 
 
<!-- PHP MYSQL -->
 
$checkboxArray=$HTTP_POST_VARS['language'];
$xml_upload_dir= 'xml/';
 
 
 if(isset($_FILES['files']['tmp_name'])){
        for($i=0; $i < count($_FILES['files']['tmp_name']);$i++)		
        {
 if(@copy($_FILES['files']['tmp_name'][$i],$xml_upload_dir.'/'.$_FILES['files']['name'][$i])) {
$fileName = $_FILES['files']['name'][$i];
foreach($checkboxArray as $language)
{
$query="INSERT INTO TABLENAME(entryID, language, fileName) VALUES ('$entryID', '$language', '$fileName')"; 
$result=mysql_query($query);
        }
    }
	
}

Open in new window

rasoodockAsked:
Who is Participating?
 
NerdsOfTechConnect With a Mentor Technology ScientistCommented:
Oops one to many }.. USE THIS VERSION INSTEAD.
<!-- FORM SAMPLE -->
 
<input type="checkbox" name="language[]" value="en" />EN
<input type="checkbox" name="language[]" value="de" />DE
<input type="checkbox" name="language[]" value="fr" />FR
 
<!-- The file upload fields only display after selecting the relevant checkbox -->
 
<input name="files[]" type="file" />File EN
<input name="files[]" type="file" />File DE
<input name="files[]" type="file" />File FR
 
 
 
<!-- PHP MYSQL -->
 
$checkboxArray=$HTTP_POST_VARS['language'];
$xml_upload_dir= 'xml/';
 
 
if(isset($_FILES['files']['tmp_name']))
{
 for($i=0; $i < count($_FILES['files']['tmp_name']);$i++)                
 {
  if(@copy($_FILES['files']['tmp_name'][$i],$xml_upload_dir.'/'.$_FILES['files']['name'][$i]))
  {
   $fileName = $_FILES['files']['name'][$i];
   $language = $checkboxArray[$i];
   $query="INSERT INTO TABLENAME(entryID, language, fileName) VALUES ('$entryID', '$language', '$fileName')"; 
   $result=mysql_query($query);
  }
 }   
}

Open in new window

0
 
racekCommented:

INSERT INTO TABLENAME(entryID, language, fileName) 
VALUES 
('$entryID', '$language', '$fileName'),
('$entryID', '$language', '$fileName'),
('$entryID', '$language', '$fileName')

Open in new window

0
 
racekCommented:
you can have several times values in one insert ... without foreach...
0
Cloud Class® Course: Microsoft Office 2010

This course will introduce you to the interfaces and features of Microsoft Office 2010 Word, Excel, PowerPoint, Outlook, and Access. You will learn about the features that are shared between all products in the Office suite, as well as the new features that are product specific.

 
rasoodockAuthor Commented:
Hi racek,

Thanks, but it will not necessarily be a maximum of three fields / checkboxes submitted.  Also re. the foreach, I will still need this to extract the values within the checkbox array.

The checkboxes / file upload fields are dynamically created.


0
 
NerdsOfTechTechnology ScientistCommented:
looks like you have 2 loops instead of one. So you are probably getting:

file1
file1
file1
file2
file2
file2
file3
file3
file3

Try just one loops and take the $i for the index of the checkbox array instead :)

Try and post errors if any.

<!-- FORM SAMPLE -->
 
<input type="checkbox" name="language[]" value="en" />EN
<input type="checkbox" name="language[]" value="de" />DE
<input type="checkbox" name="language[]" value="fr" />FR
 
<!-- The file upload fields only display after selecting the relevant checkbox -->
 
<input name="files[]" type="file" />File EN
<input name="files[]" type="file" />File DE
<input name="files[]" type="file" />File FR
 
 
 
<!-- PHP MYSQL -->
 
$checkboxArray=$HTTP_POST_VARS['language'];
$xml_upload_dir= 'xml/';
 
 
if(isset($_FILES['files']['tmp_name']))
{
 for($i=0; $i < count($_FILES['files']['tmp_name']);$i++)                
 {
  if(@copy($_FILES['files']['tmp_name'][$i],$xml_upload_dir.'/'.$_FILES['files']['name'][$i]))
  {
   $fileName = $_FILES['files']['name'][$i];
   $language = $checkboxArray[$i];
    $query="INSERT INTO TABLENAME(entryID, language, fileName) VALUES ('$entryID', '$language', '$fileName')"; 
    $result=mysql_query($query);
   }
  }
 }   
}

Open in new window

0
 
rasoodockAuthor Commented:
This works fine to an extent but still having problems with inserting the checkbox values which appear to behave very inconsistently.

For instance generally (though NOT always) if the first two are selected (e.g EN and DE) these values are inserted without a problem.

However if non-consecutive checkboxes are checked e.g  EN and FR  or if EN is omitted the values are not inserted.

Thanks for your help!

0
 
rasoodockAuthor Commented:
Apologies!  The checkbox inconsistency was due to a jquery hide/reveal function.  Other your solution works perfectly.  

Many thanks again.
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.