Jump to content

Recommended Posts

What I have is a page with a list of cars, each with a checkbox next to them.

 

<?php
$sth = null; $count = 0;
$sth = $dbh->prepare("SELECT * FROM garage WHERE warehouse_id = ? ORDER BY car_name ASC");
$sth->execute(array($_POST['ware_id']));
echo "<table>";
echo "<tr>";
echo '<td>Choose Vehicles:</td>';
echo "</tr>";
echo "<tr>";
echo "<td>";

echo "<form action='warehouse_ship_3.php' method='POST'>";
while($row = $sth->fetch()){
echo "<input type='checkbox' name='cars' value='".$row['uci']."' /> ID: ".$row['uci'].", ".$row['car_year']." ".$row['car_name']."<br />";  
}
echo "<input type='hidden' name='ware_id' value='".$_POST['ware_id']."' />";
echo "<hr />";
echo '<div class="center"><input class="myButton" type="submit" name="submit" value="Next" /></div></form>';
echo "</td>";
echo "</tr>";
echo "</table>";

?>

 

That works fine. What I'm trying to do with this second page, is select all the car's info from a table called "garage" which stores data for all the cars (car name, year, etc) and display it. UCI stands for Unique car id, every car has a different id. It works when the user only selects one car on the previous page, but if they select two or more cars, only the car with the highest UCI number shows up. How would I work it to display info on every car that they selected?

 

<?php
  if(empty($_POST['cars']))
  {
    echo("You didn't select any cars.");
  }
  else
  {
$sth = $dbh->prepare("SELECT * FROM `garage` WHERE `uci` = ?");
$sth->execute(array($_POST['cars']));
while($cars = $sth->fetch()){

echo"
".$cars['uci'].", ".$cars['car_year']." ".$cars['car_name']."
";
}
  }
?>

Link to comment
https://forums.phpfreaks.com/topic/259079-displaying-multiple-checkbox-values/
Share on other sites

First you need to change the checkbox name in the form so that it POSTs an array of selected ids (note the empty square brackets):

 

<input type='checkbox' name='cars[]' value='" ...

 

Then you need to change your WHERE clause to select multiple cars.

 

SELECT * FROM garage WHERE uci IN (1, 2, 3)

 

I'd show the PHP for that, too, but I don't work with prepared statements, so I'm not sure how it would go. In standard code, it would be

 

$sql = 'SELECT * FROM garage WHERE uci IN (' . implode(',', $_POST['cars']) . ')';

 

Of course, you'd need to sanitize those inputs, first.

I got it working with Prepared Statements. Here's the PDO query:

 

$ids = $_POST['cars'];
foreach($ids as &$val)
   	$val=$dbh->quote($val); //iterate through array and quote
$in = implode(',',$ids); //create comma separated list
$stmt = $dbh->query(
    		'SELECT *
     		FROM garage
     		WHERE uci IN('.$in.')'
);
while ($cars = $stmt->fetch()) {

 

 

Thanks again for your help!

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.