Coś takiego?
<select name="pulldown1">
<option value="default">Choose an option</option>
<?php
include("connect.php"); /*file where you have stored your DB conn. settings*/
$result = mysql_query('SELECT id, lastname, firstname FROM spusername ORDER BY firstname ASC') or die (mysql_error());
while ($row = mysql_fetch_array($result)) {
echo '<option value="' . htmlentities($row['id'], ENT_QUOTES) . ' ' . htmlentities($row['lastname'], ENT_QUOTES) . ' ' . htmlentities($row['firstname'], ENT_QUOTES) . '">' . htmlentities($row['lastname'], ENT_QUOTES) . ', ' . htmlentities($row['firstname'], ENT_QUOTES) . '</option>';
}
?>
</select>
<select name="pulldown2">
<option value="default">Choose and option</option>
<?php
$result = mysql_query('SELECT traingtype FROM trainingtable ORDER BY trainingname ASC') or die (mysql_error());
while ($row = mysql_fetch_array($result)) {
echo '<option value="' . $row['trainingtype'] . '">' . $row['trainingtype'] . '" "' . $row['lastname'] . '</option>';
}
?>
</select>
Spowoduje to powstanie dwóch menu rozwijanych, w których pierwsze menu rozwijane zawiera nazwisko i imię użytkownika oddzielone przecinkiem + spację, a drugie zawiera listę różnych typów szkoleń. Podany identyfikator jest wysyłany tylko przez zmienną, ale nie jest wyświetlany użytkownikowi.
Podczas wyciągania wartości ze zmiennej w pulldown1, po prostu użyj polecenia eksploduj:
$userdetails = $_POST['pulldown1'];
$values = explode(" " $userdetails);
$ID = $values[0];
$lastname = $values[1];
$firstname = $values[2];
Nie testowałem kodu, więc może wymagać poprawek i oczywiście musisz zmienić nazwy zmiennych odpowiadające twoim rzeczywistym nazwom wierszy w bazie danych.
Edycja:w swoim kodzie musisz użyć $row, a nie $row2.
Po drugie, zamiast tego:
<option value='{$id}'>{$lastname},{$firstname}</option>
użyj tego:
<option value="' . $row['id'] . '">' . $row['lastname'] . ', ' . $row['firstname'] . '</option>