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 :

Comparer des chaines de caractères comme des nombres


Sujet :

Requêtes MySQL

  1. #1
    Membre habitué
    Homme Profil pro
    Owner
    Inscrit en
    Décembre 2004
    Messages
    466
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Owner
    Secteur : Santé

    Informations forums :
    Inscription : Décembre 2004
    Messages : 466
    Points : 137
    Points
    137
    Par défaut Comparer des chaines de caractères comme des nombres
    Salut,
    J'ai à comparer des nombres malheureusement stockés sous forme de chaînes de caractères
    Est-il possible de comparer par exemple 20140315081034 à 20140412102515 comme ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT COUNT(result) FROM qc_res  WHERE  DATETIMERES < 'DatetimeresstrMax' AND DATETIMERES > 'DatetimeresstrMin'
    DATETIMERES étant une date longue stockée en VARCHAR
    DatetimeresstrMax et DatetimeresstrMin étant des variables string
    (toutes deux par exemple 20140315081034)

    Malheureusement je n'y arrive pas
    Qui peut m'aider?


    Merci d'avance

  2. #2
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 031
    Points
    34 031
    Billets dans le blog
    14
    Par défaut
    Utilisez CAST pour transformer votre chaîne de caractères en nombre ou en date.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT COUNT(result) 
    FROM qc_res  
    WHERE  CAST(DATETIMERES AS DATE) < CAST('$DatetimeresstrMax' AS DATE) 
        AND CAST(DATETIMERES AS DATE) > CAST('$DatetimeresstrMin' AS DATE)
    Encore mieux : utilisez BETWEEN en plus de CAST au lieu de < et >
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  3. #3
    Membre habitué
    Homme Profil pro
    Owner
    Inscrit en
    Décembre 2004
    Messages
    466
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Owner
    Secteur : Santé

    Informations forums :
    Inscription : Décembre 2004
    Messages : 466
    Points : 137
    Points
    137
    Par défaut
    Bouououuuhhh
    Comment coder ça en Delphi? COmment coder le '$'???
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Query.SQL.Add('SELECT COUNT(result) FROM qc_res  WHERE QC_Lot LIKE ' +quotedStr(Lot)+
                    ' AND CAST(DATETIMERES AS DATE) < CAST($'+(DatetimeresstrMax)+' AS DATE)'+
                    ' AND CAST(DATETIMERES AS DATE) > CAST($'+(DatetimeresstrMin)+' AS DATE)'+
                    ' AND Instr_ID = '+quotedStr(machine1)+' AND Test = '+quotedStr(QCListBox.Items.strings[QCListBox.ItemIndex]));



  4. #4
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 031
    Points
    34 031
    Billets dans le blog
    14
    Par défaut
    J'avais ajouté le $ parce que je pensais qu'il s'agit de variables en PHP.

    Formellement, dans la requête que vous aviez donnée, vous faisiez une comparaison entre des dates et des chaînes de caractères fixes 'DatetimeresstrMax' et 'DatetimeresstrMin' ce qui n'aurait donné aucun résultat.
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  5. #5
    Membre habitué
    Homme Profil pro
    Owner
    Inscrit en
    Décembre 2004
    Messages
    466
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Owner
    Secteur : Santé

    Informations forums :
    Inscription : Décembre 2004
    Messages : 466
    Points : 137
    Points
    137
    Par défaut
    Salut CinePhil,
    En fait ce sont deux variables que je récupère avant le traitement.
    J'avais aussi testé ça (en Deplhi)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Query.SQL.Add('SELECT COUNT(result) FROM qc_res  WHERE QC_Lot LIKE ' +quotedStr(Lot)+
                    ' AND CAST(DATETIMERES AS DATE) < CAST('+quotedStr(DatetimeresstrMax)+' AS DATE)'+
                    ' AND CAST(DATETIMERES AS DATE) > CAST('+quotedStr(DatetimeresstrMin)+' AS DATE)'+
                    ' AND Instr_ID = '+quotedStr(machine1)+' AND Test = '+quotedStr(QCListBox.Items.strings[QCListBox.ItemIndex]));
    ...mais ne renvoie rien
    J'ai songé aussi à utiliser UTC_TIMESTAMP:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT UTC_TIMESTAMP(), UTC_TIMESTAMP() + 0;
            -> '2003-08-14 18:08:04', 20030814180804.000000
    ...puisque j'ai deux chaines de ce type (20140315081034)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Query.SQL.Add('SELECT COUNT(result) FROM qc_res  WHERE QC_Lot LIKE ' +quotedStr(Lot)+
                    ' AND UTC_TIMESTAMP(DATETIMERES)+0 < UTC_TIMESTAMP('+quotedStr(DatetimeresstrMax)+')+0)'+
                    ' AND UTC_TIMESTAMP(DATETIMERES)+0 > UTC_TIMESTAMP('+quotedStr(DatetimeresstrMin)+')+0)'+
                    ' AND Instr_ID = '+quotedStr(machine1)+' AND Test = '+quotedStr(QCListBox.Items.strings[QCListBox.ItemIndex]));
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Query.SQL.Add('SELECT COUNT(result) FROM qc_res  WHERE QC_Lot LIKE ' +quotedStr(Lot)+
                    ' AND UTC_TIMESTAMP(DATETIMERES) < UTC_TIMESTAMP('+quotedStr(DatetimeresstrMax)+')'+
                    ' AND UTC_TIMESTAMP(DATETIMERES) > UTC_TIMESTAMP('+quotedStr(DatetimeresstrMin)+')'+
                    ' AND Instr_ID = '+quotedStr(machine1)+' AND Test = '+quotedStr(QCListBox.Items.strings[QCListBox.ItemIndex]));
    mais aucun n'est ok


  6. #6
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 031
    Points
    34 031
    Billets dans le blog
    14
    Par défaut
    Puisque vos dates semblent être des entiers, si vos variables sont également des entiers, vous pouvez utiliser CAST(DATETIMERES AS UNSIGNED)
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

Discussions similaires

  1. Réponses: 2
    Dernier message: 07/08/2012, 16h20
  2. Comparer 2 chaines de caractère contenant des float
    Par Korben-Dallas dans le forum C
    Réponses: 14
    Dernier message: 17/05/2011, 13h26
  3. Réponses: 2
    Dernier message: 13/05/2009, 10h11
  4. Réponses: 6
    Dernier message: 21/02/2008, 21h17
  5. Réponses: 2
    Dernier message: 13/05/2007, 18h34

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