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 :

[SQL] Fonction de date et heure


Sujet :

PHP & Base de données

  1. #1
    Membre averti
    Inscrit en
    Mai 2006
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 33
    Par défaut [SQL] Fonction de date et heure
    Bonjour , j'ai actuelement une base de données dans laquelle est definit la date de fin de contrat d'un client.
    J'aimerai faire une requete permetant de selectionner les clients ayant leur contrat se terminant sous les 30 jours.

    Par exemple :
    - Martin Albert => fin de contrat le 29/12/09 : ok
    - Martin Benoit => fin de contrat le 12/08/07 : expiration dans moins d'un moi !

    Alors la requete nous permetrai pour dans ce cas , d'afficher tout les client en fin de contrat..
    Je suis aller voir la documentation des fonction de date et heure mais je suis perdu
    Une ame charitable pour me mettre sur la voie ?

    Merci d'avance

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 134
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 134
    Par défaut
    Tout simplement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT ...
    WHERE fin_contrat < CURRENT_DATE + 30
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Membre Expert

    Profil pro
    Inscrit en
    Avril 2005
    Messages
    1 673
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 1 673
    Par défaut
    Cf. les règles du forum : SGBD et version ?

  4. #4
    Membre averti
    Inscrit en
    Mai 2006
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 33
    Par défaut
    Pourquoi faire compliquer quand on peut faire simple ^^.
    Une autre petite question , faut-il plustot utiliser un while ou un for apres ma requete pour parcourir toute la table ?

    La requete serait de ce type la :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $requete = mysql_query("SELECT societe FROM fr_contrat WHERE finContrat > CURRENT_DATE + 30");
     
    while($row = mysql_fetch_array($requete)){
    $date=$row['finContrat'];
    }
    J'obtiens bien les clients dont le contrat est bientot expiré ?
    Je suis désolé d'etre nul , j'apprends tt seul et c pas facil desfois meme si pour vous cela doit etre evident ^^

    Ps: a mon avis i lfaudrait plustot un for ici , ce qui nous permetrait de parcourir tout les clients enregistrés dans la base de données et ainsi voir ceux en fin de contrat , non ?

    Je travail avec easyPhp 1.8.0.1

  5. #5
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 134
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 134
    Par défaut
    Citation Envoyé par dudezerff
    Une autre petite question , faut-il plustot utiliser un while ou un for apres ma requete pour parcourir toute la table ?
    Cela n'est plus du ressort du langage SQL mais de ton langage applicatif.
    La question est à poser sur le forum correspondant.

    ... et je n'ai aucune idée sur la question.
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  6. #6
    Membre averti
    Inscrit en
    Mai 2006
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 33
    Par défaut
    Bonjour , je me suis remis au travail ce matin :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $sql2='SELECT societe FROM fr_contrat WHERE finContrat > CURRENT_DATE + 30';
     
    $requete3=mysql_query($sql2) or die(mysql_error());
     
     
    while($data = mysql_fetch_array($requete3))
    {
        echo ' <i>Societe : '.$data['societe'].'</i><br>'; 
    }
    Donc apparement je n'arrive pas a rentrer dans le while .En notifiant une autre requete qui marche , je rentre dedans .
    Je ne vois pas l'erreur dans la requete, j'ai essayer d'executer la requete sous phpMyAdmin et je n'ai pas d'erreur ...
    Merci d'avance pour un coup de pouce

  7. #7
    Membre éclairé Avatar de cyreel
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2004
    Messages
    388
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2004
    Messages : 388
    Par défaut
    essai avec ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    $sql2='SELECT societe FROM fr_contrat WHERE finContrat > CURRENT_DATE + 30';
     
    $requete3=mysql_query($sql2) or die(mysql_error());
     
     
    while($data = mysql_fetch_array($requete3))
    {
        echo ' <i>Societe : '.$data[societe].'</i><br>'; 
    }

  8. #8
    Membre expérimenté

    Profil pro
    Inscrit en
    Juin 2002
    Messages
    6 152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 6 152
    Par défaut
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT societe FROM fr_contrat WHERE `finContrat` BETWEEN NOW() AND NOW() + INTERVAL 1 MONTH;


    Parce qu'ajouter un nombre à une date c'est comme ajouter des brouettes et des cacahouètes

  9. #9
    Membre averti
    Inscrit en
    Mai 2006
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 33
    Par défaut
    Bonjour , j'ai fais comme ca et cela marche :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sql3="SELECT societe, finContrat FROM fr_contrat WHERE finContrat < DATE_ADD(CURRENT_DATE, INTERVAL 31 DAY)";

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

Discussions similaires

  1. Fonction qui trouve l'heure et la date???
    Par snake77350 dans le forum C
    Réponses: 6
    Dernier message: 28/04/2006, 14h45
  2. [SQL] un champ Timestamp ou deux champs Date et Heure?
    Par davmaster62 dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 25/02/2006, 23h04
  3. [sql server] requête sur dates et heures (format du résultat
    Par isachat666 dans le forum Langage SQL
    Réponses: 1
    Dernier message: 21/02/2006, 13h48
  4. [SQL] selection des dates en ne distinguant pas l'heure
    Par meufeu dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 01/06/2005, 11h29
  5. Réponses: 8
    Dernier message: 05/05/2004, 12h30

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