|
|
|
|
Bonjour,
Je me casse la tête depuis plusieurs jours avec les dates !!
Voici mon problème : le visiteur insère dans un champ sa date de naissance (au format jj/mm/aaaa). Jusque la tout va bien. Mais impossible de convertir cette date en format américain (yyyy-mm-dd) pour la rentrer dans MySQL !! Quelqu'un peu t-il m'aider svp =( J'ai fait de nombreux forums mais impossible de trouver la réponse...
Voici mon code :
<?php
mysql_connect("localhost", "Boum", "");
mysql_select_db("Test");
if (isset($_POST['dateNaissance']))
{
$dateNaissance = mysql_real_escape_string(htmlspecialchars($_POST['dateNaissance']));
mysql_query("INSERT INTO Membre VALUES('" . STR_TO_DATE('$dateNaissance', '%d/%m/%Y') . "')");
}
?>
PS : je suis débutant en PHP/MySQL...
Configuration: Windows Vista Firefox 3.0.9
Voilà:
if (isset($_POST['dateNaissance'])){
$dateNaissance_fr=htmlspecialchars($_POST['dateNaissance']);
$array_date_naissance=explode("/",$dateNaissance_fr);
$dateNaissance_mysql=$array_date_naissance[2]."-".$array_date_naissance[1]."-".$array_date_naissance[0];
mysql_query("INSERT INTO Membre VALUES('" . mysql_escape_string($dateNaissance_mysql)."')"); //attention tu dois mettre les values dans l'ordre de tes champs de ta table |
Avec un explode() simplement. if( !empty($_POST['dateNaissance']) )
{
if( preg_match('#^\d{2}/\d{2}/\d{4}$#', $_POST['dateNaissance']) )
{
$date = explode('/', $_POST['dateNaissance']);
if( checkdate($date[1], $date[0], $date[2]) )
{
$sql = "INSERT INTO Membre VALUES('" . $date[2] . '-' . $date[1] . '-' . $date[0] . "')";
mysql_query($sql);
}
else
{
// Date invalide
}
}
else
{
// Format invalide
}
}
else
{
// Champ vide
}Tu peux encore affiner la chose en vérifiant que la date fournie est par exemple supérieure à 1900 et inférieure à celle (d'aujourd'hui moins 10ans). |