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

Langage SQL Discussion :

problème de requête SQL


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Décembre 2006
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Décembre 2006
    Messages : 57
    Par défaut problème de requête SQL
    Bonjour!

    J'ai un champs dans une table dans lequel je retrouve le nom des rues inscrites de la façon suivante

    "ROME,BOULEVARD"

    Par contre dans le fichier texte, j'ai seulement "ROME".

    Es-ce possible de faire une requête sql sur la partie du champs qui se trouve avant la virgule et ne pas tenir compte du reste.

    Je voudrais éviter de faire un LIKE puisque la requête pourrait me retourner plusieurs enregistrements contenant les lettre ROME.

    Merci de votre aide

    Alexandre

  2. #2
    Membre chevronné Avatar de AL1986
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    434
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 434
    Par défaut
    Citation Envoyé par gibea00 Voir le message
    Es-ce possible de faire une requête sql sur la partie du champs qui se trouve avant la virgule et ne pas tenir compte du reste.

    Je voudrais éviter de faire un LIKE puisque la requête pourrait me retourner plusieurs enregistrements contenant les lettre ROME.
    Tu ne veux prendre en considération que les adresses commençant par ROME. Je ne voix pas où est le pb si tu le fais avec un like "ROME%". Même si tu le fais sans like, tu auras plusieurs enregistrements. Sinon essaie de préciser un peu plus.

  3. #3
    Membre confirmé
    Inscrit en
    Décembre 2006
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Décembre 2006
    Messages : 57
    Par défaut
    Ce que je voudrais c'est que la requête ne retourne pas plusieurs enregistrements.

    Pour en revenir à mon exemple :

    Admettons que dans ma table j'ai 2 enregistrements.
    "ROME,RUE"
    "ROMEO,RUE"

    Dans mon fichier texte, je reçois "ROME". Je voudrais faire une requête qui me retournerais seulement le 1er enregistrement de ma table soit "ROME,RUE".

    Si je fais un LIKE 'ROME%" j'aurai les 2. C'est pour ça que j'aiemrais pouvoir faire une requête seulement sur la partie qui ce trouve avant la virgule.

    Es-ce possible ?

    Merci

  4. #4
    Membre chevronné Avatar de AL1986
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    434
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 434
    Par défaut
    et avec ?

  5. #5
    Membre chevronné Avatar de AL1986
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    434
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 434
    Par défaut
    Sous ORACLE il y a deux méthodes
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    substr(string, position)
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    substr(string, position, length)
    . Mais je pense que cela revient à faire la même chose qu'un like. Genre dans le where tu mets
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    where substr(adresse, 1, 5)="ROME,"

  6. #6
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 136
    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 136
    Par défaut
    Pour extraire la partie de la chaîne précédant la virgule, tu peux utiliser l'expression suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SUBSTRING(macolonne, 1, POSITION(',' IN macolonne) - 1)
    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.

Discussions similaires

  1. Problème de requête SQL avec instruction TRANSFORM
    Par Nosper dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 21/06/2005, 16h15
  2. problème de requète SQL pour formulaire
    Par en_stage dans le forum Requêtes et SQL.
    Réponses: 15
    Dernier message: 21/06/2005, 12h21
  3. [SQL] Problème de requête SQL de plus de 8060 caractères ?
    Par webtheque dans le forum MS SQL Server
    Réponses: 13
    Dernier message: 06/04/2005, 15h07
  4. [SQLserver2000][SQLServer CE] problème de requête SQL
    Par JBernn dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 27/01/2005, 09h29
  5. Problème de requète SQL dans un Requery
    Par Keraccess dans le forum Requêtes et SQL.
    Réponses: 7
    Dernier message: 22/10/2004, 14h58

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