A tu primera pregunta no puedo contestarte, nunca he trabajado en bases de datos con un campo marcado como date. Todos los campos de fechas los barajo por separado como int o todos juntos como varchar.
Para unir campos de una lista de selección solo habría que encadernlos con puntos (.), pero no tengo la menor idea de como lo trabaja un date. Puedes guiarte un poco con este ejemplo.
Código PHP:
Ver original<?php
$fecha_entera=$_POST['seleccion1'].'/'.$_POST['seleccion2'].'/'.$_POST['seleccion3'];
/* Ejemplo de encadenación de variables para hacer una fecha */
?>
Sobre agregarle un cero, es relativamente fácil, solo hay que comprobar que cuando el número del mes sea inferior a 10, añadirle un cero como string de relleno. Y aquí tu código para que esto funcione:
Código PHP:
Ver original<?php
$fecha_year = date ("Y");
echo "<select name=\"dia\">\n";
for ($contador=1; $contador <=31; $contador++){
if ($fecha_dia==$contador){
echo "<option value=\"".$contador."\" selected>".$contador."\n";
}else{
echo "<option value=\"".$contador."\">".$contador."\n";
}
}
echo "</select>\n";
echo "<select name=\"mes\">\n";
for ($contador=1; $contador <=12; $contador++){
if($contador<10){$ceroExtra="0";}else{$ceroExtra="";}
if ($fecha_mes==$contador){
echo "<option value=\"".$contador."\" selected>".$ceroExtra.$contador."\n";
}else{
echo "<option value=\"".$contador."\">".$ceroExtra.$contador."\n";
}
}
echo "</select>\n";
echo "<select name=\"year\">\n";
for ($contador=2005; $contador <=2025; $contador++){
if ($fecha_year==$contador){
echo "<option value=\"".$contador."\" selected>".$contador."\n";
}else{
echo "<option value=\"".$contador."\">".$contador."\n";
}
}
echo "</select>\n";
?>
Supongo que es simple y fácil visto ahora.
Suerte con tu primera cuestión y tu programación.