IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

Récupérer une date d'un input et le stocker dans la base de donnée [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre confirmé
    Homme Profil pro
    Développeur Java
    Inscrit en
    Décembre 2015
    Messages
    39
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2015
    Messages : 39
    Par défaut Récupérer une date d'un input et le stocker dans la base de donnée
    Bonjour,
    Je suis un nouveau petit noob parmis le PHP. Donc j'ai suivis quelque tutoriel, mais je me suis perdu au moment du stockage d'une date.
    J'ai un <input type="date" ... j'aimerais récupérer la date sélectionner dans ce input afin de pouvoir l'envoyez vers ma base, et ensuite l'afficher sur ma page simplement.
    J'ai regarder sur internet j'ai pas vraiment compris, où peut-être pas vraiment trouvé.

    Voici mon code :

    Date.php

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
     
    <!DOCTYPE html>
    <html>
    <head>
      <meta charset="utf-8" />
      <title>Date</title>
    </head>
    <body>
     
    <form action="date_post.php" method="post">
        <p>
            <label>Pseudo : </label><input type="text" name="pseudo" id="pseudo">
        </p>
        <p>
            <label>Message : </label><textarea placeholder="Entrer votre message" name="message" id="message"></textarea>
        </p>
        <input type="date" class="form-control" size="30" name="date_1" id="date_msg" />
        <p>
            <input type="submit" value="Envoyer" />
        </p>
    </form>
     
    <?php
    try
    {
        $bdd = new PDO('mysql:host=localhost;dbname=test;charset=utf8', 'root', '');
    }
    catch(Exception $e)
    {
        die('Erreur : '.$e->getMessage());
    }
     
    $reponse = $bdd->query('SELECT  date_1 FROM date_db');
     
    echo '<p>Voici la date  :</p>' . $_GET['date_1'];
     
    ?>
     
    </body>
    </html>
    Et le code de date_post.php :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
     
     
    <!DOCTYPE html>
    <html>
    <head>
      <meta charset="utf-8" />
      <title>Date</title>
    </head>
    <body>
     
    <?php
     
    try
    {
    	$bdd = new PDO('mysql:host=localhost;dbname=test;charset=utf8', 'root', '');
    }
    catch(Exception $e)
    {
            die('Erreur : '.$e->getMessage());
    }
     
    $date = date($_POST['date_1'], strtotime($date));
     
     
    $req = $bdd->prepare('INSERT INTO date_db (date_1) VALUES($date)');
    $req->execute(array($_POST['date_1']));
    header('Location: date.php');
    ?>
     
    </body>
    </html>
    Sachant que ma table s'appelle "date_db".
    En gros je voudrais le code source d'après avoir cliquer sur le bouton comme c'est fait : http://www.w3schools.com/html/tryit....tml_input_date
    Merci d'avance pour vos réponse. Et pardon si une tel question à déjà (sûrement même) été posée.

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    N'hésite pas à te reporter à la doc :
    http://php.net/manual/fr/function.date.php

    date() sert à produire une date dans un format donnée et le premier argument de la fonction est le format, pas la date.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    if (isset($_POST['date_1'])) {   // si on a reçu une valeur du formulaire
        $objdate = date_create_from_format('d/m/Y', $_POST['date_1']);   // on crée un objet datetime depuis un format français
        if ($objdate !== FALSE) {  // si on a pu créer l'objet
                  $date = $objdate->format('Y-m-d');   // on produit un format de date mysql
                  $req = $bdd->prepare('INSERT INTO date_db (date_1) VALUES (?)'); // on prépare la requête en mettant la valeur en paramètre
                  $req->execute(array($date));  // on execute la requête avec notre date mysql comme valeur
        }
    }
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre très actif
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    251
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 251
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $reponse = $bdd->query('SELECT  date_1 FROM date_db');
     
    echo '<p>Voici la date  :</p>' . $_GET['date_1'];
    Déjà là y a problème. D'où sort ton $_GET et à quoi sert $reponse ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $date = date($_POST['date_1'], strtotime($date));
    Ca m'a pas l'air très bon non plus.
    strtotime($date) ne doit pas servir à grand chose vu que $date n'est pas initialisé.
    Ton date( $_post, ... ) tu devrais regarder la doc, le premier paramètre c'est le format que tu veut avoir en retour.

    La subtilité de strtotime c'est qu'il ne comprend pas les dates en jj/mm/aaaa. Il faut utiliser un str_replace pour qu'il comprennent le format de la date.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $date = date('Y-m-d', strtotime(str_replace('/','-',$_POST['date_1']));
    devrait mieux marcher

  4. #4
    Membre confirmé
    Homme Profil pro
    Développeur Java
    Inscrit en
    Décembre 2015
    Messages
    39
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2015
    Messages : 39
    Par défaut C'est bon !
    C'est bon j'ai réussi ! Je vous remercie pour tout.
    Voici mon code :
    Pour le date.php
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
     
    <!DOCTYPE html>
    <html>
    <head>
      <meta charset="utf-8" />
      <title>Date</title>
    </head>
    <body>
     
    <form action="date_post.php" method="post">
        <p>
            <label>Pseudo : </label><input type="text" name="pseudo" id="pseudo">
        </p>
        <p>
            <label>Message : </label><textarea placeholder="Entrer votre message" name="message" id="message"></textarea>
        </p>
        <input type="date" class="form-control" size="30" name="date_1" id="date_1" />
        <p>
            <input type="submit" value="Envoyer" />
        </p>
    </form>
     
    <?php
    try
    {
        $bdd = new PDO('mysql:host=localhost;dbname=test;charset=utf8', 'root', '');
    }
    catch(Exception $e)
    {
        die('Erreur : '.$e->getMessage());
    }
     
     $answer =  $bdd->query('SELECT  date_1 FROM date_db');
    echo 'Voici les dates que contiens la data base : ';
    while ($donnees = $answer->fetch())
    echo '</br>' . $donnees['date_1'];
    ?>
     
    </body>
    </html>
    Et le code pour le code_post.php :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
     
    <!DOCTYPE html>
    <html>
    <head>
      <meta charset="utf-8" />
      <title>Date</title>
    </head>
    <body>
     
    <?php
     
    try
    {
    	$bdd = new PDO('mysql:host=localhost;dbname=test;charset=utf8', 'root', '');
    }
    catch(Exception $e)
    {
            die('Erreur : '.$e->getMessage());
    }
     
     
    if (isset($_POST['date_1'])) {   // si on a reçu une valeur du formulaire
        $date = date('Y-m-d', strtotime(str_replace('/','-',$_POST['date_1'])));
        if ($date !== FALSE) {  // si on a pu créer l'objet
            $req = $bdd->prepare('INSERT INTO date_db (date_1) VALUES (?)');
            $req->execute(array($date));
        }else{
            echo 'error';
        }
    }
    header('Location: date.php');
    ?>
     
     
     
    </body>
    </html>
    Encore merci .

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 4
    Dernier message: 23/02/2013, 12h48
  2. Récupérer une date depuis une page ASP dans une BDD
    Par franckrichard57 dans le forum ASP
    Réponses: 2
    Dernier message: 22/03/2007, 11h31
  3. [Conception] Récupérer une date au format francophone
    Par HwRZxLc4 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 08/11/2006, 16h15
  4. Réponses: 5
    Dernier message: 01/06/2006, 11h36
  5. Réponses: 1
    Dernier message: 07/06/2005, 14h00

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo