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 et SQL. Discussion :

SELECT MAX sur un champ de type chaîne [AC-2003]


Sujet :

Requêtes et SQL.

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 206
    Points : 243
    Points
    243
    Par défaut SELECT MAX sur un champ de type chaîne
    Bonsoir à tous,

    J'ai mis au point un petit algorithme pour créer les clés primaires des enregistrements dans le type ' EXT14', 'EXT15', etc ...

    La requête
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT MAX(RefMateriel) As Max FROM Materiel
    affiche bien le dernier jusqu'à ce qu'on arrive a la barre des 100.

    Pour EXT99, il affecte bien la clé EXT100 mais à partir de EXT100 la requête sélectionne toujours EXT99 et donc les enregistrements ne fonctionnent plus

    Quelqu'un saurait-il d'où provient le problème ?

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour

    Tu es sur un champ alphanumérique (lettres + chiffres), et donc Ext100 sera toujours avant Ext99, de même que Ext10000000000000 (en exagérant).

    Donc ton Max sera toujours Ext99 quoi que tu fasses, le MAX que tu veux ne peux fonctionner que sur un champ exclusivement numérique.

    Philippe

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    37
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 37
    Points : 30
    Points
    30
    Par défaut Une solution parmi d'autres
    Le code suivant le permettra :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT MAX(Val(RefMateriel)) As Max FROM Materiel
    Val retournant la valeur numérique contenue dans la chaîne de caractères.

  4. #4
    Membre actif
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 206
    Points : 243
    Points
    243
    Par défaut
    Merci pour vos réponses.

    J'avais modifier mon code pour contourner le problème mais du coup je vais utiliser la solution de divan.

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 26/08/2011, 15h24
  2. [MySQL] SELECT MAX() sur 2 champs
    Par patguits dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 21/09/2007, 14h03
  3. select max sur champ alphanumérique ?
    Par clawhammer dans le forum SQL
    Réponses: 3
    Dernier message: 16/10/2006, 15h00
  4. select sur un champ de type LONG
    Par ppd dans le forum Langage SQL
    Réponses: 2
    Dernier message: 03/09/2004, 18h19
  5. [Doublons] Unicité sur un champ de type TEXT
    Par PyRoFlo dans le forum Requêtes
    Réponses: 11
    Dernier message: 01/09/2004, 09h56

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