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

Requêtes MySQL Discussion :

Requête SQL sur les dates [MySQL-8.0]


Sujet :

Requêtes MySQL

  1. #1
    Membre régulier
    Homme Profil pro
    Analyste programmeur
    Inscrit en
    Septembre 2015
    Messages
    148
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : Algérie

    Informations professionnelles :
    Activité : Analyste programmeur
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2015
    Messages : 148
    Points : 92
    Points
    92
    Par défaut Requête SQL sur les dates
    Bonjour,

    Je demande votre aide sur le problème suivant:

    La table "liste_valeur" enregistre les informations suivantes : Id_client, valeur, date_enregistrement, date_valeur
    Après importation des données en format csv, dans la table liste_valeur: Id_client, valeur, date_enregistrement,
    je voudrais que la date_valeur doit être date_enregistrement - 1 c.a.d, si la date d'enregistrement = 01/08/2023 la date_valeur doit être 01/07/2023.


    Y a t'il une solution par une requête sql
    Merci

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 198
    Points : 12 774
    Points
    12 774
    Par défaut
    Bonjour,
    Tu peux trouver ton bonheur dans les fonctions sur les dates de Mysql.

    Tatayo.

  3. #3
    Expert éminent
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 104
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 104
    Points : 8 222
    Points
    8 222
    Billets dans le blog
    17
    Par défaut
    Après importation des données en format csv, dans la table liste_valeur: Id_client, valeur, date_enregistrement,
    je voudrais que la date_valeur doit être date_enregistrement - 1 c.a.d, si la date d'enregistrement = 01/08/2023 la date_valeur doit être 01/07/2023.
    -1 mois ?

    Pourquoi après import ? Cela devrait se faire pendant l'import, soit en SQL soit avec le langage faisant l'opération (PHP / Python / etc.)

    Exemple avec MySQL et PHP :

    Code PHP : 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
    $sql = <<<SQL
        INSERT INTO liste_valeur
        SET
            id_client = :id_client,
            valeur = :valeur,
            date_enregistrement = :date_enregistrement,
            date_valeur = :date_valeur
        SQL;
     
    $insert = $pdo->prepare($sql);
     
    while ( ... ) { // Parcours du CSV, ligne $record
        ...
        $insert->execute([
            'id_client' => $record['id_client'],
            'valeur' => $record['valeur'],
            'date_enregistrement' => $record['date_enregistrement'], // J'espère au format standard YYYY-MM-DD
            'date_valeur' => date('Y-m-d', strtotime("{$record['date_enregistrement']} - 1 month")),
        ]);
    }
    Un problème exposé clairement est déjà à moitié résolu
    Keep It Smart and Simple

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 136
    Points : 38 910
    Points
    38 910
    Billets dans le blog
    9
    Par défaut
    Bonjour,

    Si la règle est toujours la même, alors il est inutile de créer une colonne "date_valeur" dans la table, ce serait une redondance et donc un risque d'incohérence en cas de modification de la première colonne.
    Il est préférable de calculer cette date par requête à partir de la date d'enregistrement, par exemple dans une vue si le besoin est fréquent.

  5. #5
    Membre régulier
    Homme Profil pro
    Analyste programmeur
    Inscrit en
    Septembre 2015
    Messages
    148
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : Algérie

    Informations professionnelles :
    Activité : Analyste programmeur
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2015
    Messages : 148
    Points : 92
    Points
    92
    Par défaut
    Bonjour,

    Excusez-moi pour le retard de vous répondre, j'étais en congé
    Merci pour vos réponses, mais mon problème persiste toujours.

    Je travaille avec Mysql 8.0. Et ma date n'est pas sous le format standard YYYY-MM-DD

    Quand j'exécute la requete ci-dessous :

    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
     
    WITH
        date_releve as (select 
        a.reference, 
        concat(SUBSTR(a.date_releve, 7, 4),'/',SUBSTR(a.date_releve, 4, 2),'/',SUBSTR(a.date_releve, 1, 2)) AS date_releve_mois
       from phases a), 
     
        date_pma as (select reference,
        date(str_to_date(date_releve_mois, '%Y/%m/%d')) as date_releve_pma
        from date_releve)
     
        select a.reference, b.date_releve_pma, date(date_releve_pma - '1 month') as date_pma_reel
     
        from date_releve a
        left join date_pma b on a.reference = b.reference 
        and a.date_releve_mois = b.date_releve_pma
    Le résultat : le jour de la date égale à 00 et moi je voudrais déduire 1 mois de la date_releve_pma

    Nom : resultat.jpg
Affichages : 55
Taille : 29,2 Ko

    Merci par avance pour votre Aide

  6. #6
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    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 080
    Points : 30 802
    Points
    30 802
    Par défaut
    Bonjour,

    Quel est le type de la colonne date_releve ?
    Chaine de caractères(char, varchar) ou date ?
    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.

  7. #7
    Membre régulier
    Homme Profil pro
    Analyste programmeur
    Inscrit en
    Septembre 2015
    Messages
    148
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : Algérie

    Informations professionnelles :
    Activité : Analyste programmeur
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2015
    Messages : 148
    Points : 92
    Points
    92
    Par défaut
    Bonjour,

    Chaine de caractères

  8. #8
    Expert éminent
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 104
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 104
    Points : 8 222
    Points
    8 222
    Billets dans le blog
    17
    Par défaut
    Je travaille avec Mysql 8.0. Et ma date n'est pas sous le format standard YYYY-MM-DD
    Il suffit de les mettre au format attendu "YYYY-MM-DD" dans une colonne du type attendu "DATE".
    Ensuite tu pourras utiliser directement toutes les fonctions, et autres opérateurs, de manière normale et optimale.

    Si tu persistes sur cette (mauvaise) voix, alors il faut transformer ton texte DD/MM/YYYY en DATE avec STR_TO_DATE().
    Il n'y a pas besoin de passer par tes CONCAT() et SUBSTR().

    D'ailleurs pourquoi utiliser les séparateur "/" et pas "-" sur "YYYY/MM/DD". C'est vraiment chercher des problèmes Rien ne garantit que ce sera toujours supporté.



    select a.reference, b.date_releve_pma, date(date_releve_pma - '1 month') as date_pma_reel
    Ce n'est pas le format attendu. À supposer que tout le reste est bon, il faut faire :

    select a.reference, b.date_releve_pma, date(date_releve_pma) - interval 1 month as date_pma_reel
    Si cela ne fonctionne toujours pas donne-nous un exemple exécutable et reproductible de la situation.
    Un problème exposé clairement est déjà à moitié résolu
    Keep It Smart and Simple

  9. #9
    Membre régulier
    Homme Profil pro
    Analyste programmeur
    Inscrit en
    Septembre 2015
    Messages
    148
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : Algérie

    Informations professionnelles :
    Activité : Analyste programmeur
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2015
    Messages : 148
    Points : 92
    Points
    92
    Par défaut
    Merci Séb. pour votre réponse

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    date(date_releve_pma - interval 1 month)
    ça marche

  10. #10
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 136
    Points : 38 910
    Points
    38 910
    Billets dans le blog
    9
    Par défaut
    Citation Envoyé par noureddine1967 Voir le message
    Je travaille avec Mysql 8.0. Et ma date n'est pas sous le format standard YYYY-MM-DD
    Quel est le type SQL de cette colonne ?

  11. #11
    Expert éminent
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 104
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 104
    Points : 8 222
    Points
    8 222
    Billets dans le blog
    17
    Par défaut
    Citation Envoyé par noureddine1967 Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    date(date_releve_pma - interval 1 month)
    ça marche
    J'ai amélioré en sortant le calcul de la fonction DATE(), c'est plus sûr.
    Un problème exposé clairement est déjà à moitié résolu
    Keep It Smart and Simple

  12. #12
    Membre régulier
    Homme Profil pro
    Analyste programmeur
    Inscrit en
    Septembre 2015
    Messages
    148
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : Algérie

    Informations professionnelles :
    Activité : Analyste programmeur
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2015
    Messages : 148
    Points : 92
    Points
    92
    Par défaut
    Vous voulez dire que j'écris le code en supprimant date() ?????
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (date_releve_pma - interval 1 month)

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

Discussions similaires

  1. Utilisation fonction MIN (SQL) sur les dates
    Par fafabzh6 dans le forum SAS Base
    Réponses: 5
    Dernier message: 19/09/2008, 15h36
  2. Une requête SQL sur 2 Dates
    Par souminet dans le forum Bases de données
    Réponses: 5
    Dernier message: 14/05/2008, 20h29
  3. [CR ?] requête SQL sur une date
    Par czezko dans le forum SAP Crystal Reports
    Réponses: 2
    Dernier message: 23/04/2008, 10h25
  4. Requette SQL sur les dates
    Par willfox dans le forum Langage SQL
    Réponses: 3
    Dernier message: 12/02/2008, 17h04
  5. Requêtes SQL pour les Dates et numériques
    Par Ramage03 dans le forum Langage SQL
    Réponses: 3
    Dernier message: 23/03/2006, 17h26

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