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 :

Sélectionner la ligne X d'un champ texte [AC-2007]


Sujet :

Requêtes et SQL.

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    191
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juin 2008
    Messages : 191
    Points : 200
    Points
    200
    Par défaut Sélectionner la ligne X d'un champ texte
    Bonjour,

    je suis face à la problématique suivante : je désire alimenter une liste déroulante d'un formulaire à l'aide de la 2e ligne (et uniquement la 2e) d'un champ texte qui contient plusieurs lignes de texte. Cette liste déroulante est alimentée par une requête SQL qui va chercher directement dans une table liée les informations requises.

    En ce moment, je n'ai aucun problème à aller récupérer le contenu du champ texte (à l'aide d'une simple requête SELECT), mais c'est la 1ere ligne qui s'affiche dans ma liste déroulante et j'aimerais y voir apparaître la 2e plutôt. Aussi, il m'est impossible d'inverser l'ordre des lignes dans le champ texte (pour mettre la 2e ligne en première position par exemple), car ce champ texte est réutilisé ailleurs et l'ordre des informations a de l'importance; il me faudrait donc configurer ma requête SQL pour extraire seulement la 2e ligne, si cela est possible.

    Merci d'avance pour votre aide,
    al_bert

  2. #2
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    324
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 324
    Points : 470
    Points
    470
    Par défaut
    Comment sais-tu que quelle est la deuxième ligne? Possèdes-tu une clé (primaire) permettant d'identifier quelle ligne est la deuxième?

  3. #3
    Membre actif
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    191
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juin 2008
    Messages : 191
    Points : 200
    Points
    200
    Par défaut
    Bonjour,

    en fait il s'agit d'un champ de type mémo et non texte à proprement parler(désolé pour la confusion, je commence à être fatigué ). Chaque ligne est séparée par un "enter" (vbCrLf) de la suivante et de la précédente et c'est le seul moyen de les différencier les unes des autres.

    Merci,
    al_bert

  4. #4
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    324
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 324
    Points : 470
    Points
    470
    Par défaut
    Ah oui. J'ai compris. Avec une requête, je n'ai aucune idée de comment faire car là en fait il s'agit d'une opération sur le contenu même du champ mémo. D'autant que le retour chariot doit en plus faire croire à Access qu'il y a plus de 255 caractères pour la liste déroulante (ce qui peut expliquer, si j'ai tout compris, pourquoi il n'y a que la première ligne qui apparait, et pas le reste)... Peut-être en programmant...

  5. #5
    Membre habitué
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2010
    Messages
    175
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2010
    Messages : 175
    Points : 193
    Points
    193
    Par défaut
    Citation Envoyé par al_bert Voir le message
    Bonjour,

    en fait il s'agit d'un champ de type mémo et non texte à proprement parler(désolé pour la confusion, je commence à être fatigué ). Chaque ligne est séparée par un "enter" (vbCrLf) de la suivante et de la précédente et c'est le seul moyen de les différencier les unes des autres.

    Merci,
    al_bert

    Bonjour,
    en sachant ceci, pourquoi ne pas passer par du VBA?

  6. #6
    Membre actif
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    191
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juin 2008
    Messages : 191
    Points : 200
    Points
    200
    Par défaut
    Bonjour,

    c'est en effet une possibilité de passer par le VBA, mais je croyais qu'il était plus simple de passer par SQL que par VBA pour contrôler le contenu de ma liste déroulante. Je vais aller voir du côté du VBA en continuant mes recherches en parallèle.

    Merci,
    al_bert

  7. #7
    Expert confirmé
    Avatar de vodiem
    Homme Profil pro
    Vivre
    Inscrit en
    Avril 2006
    Messages
    2 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Vivre
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2006
    Messages : 2 895
    Points : 4 325
    Points
    4 325
    Par défaut
    salut à tous,

    il est possible d'utiliser des fonctions de manipulation de chaine dans les requetes:
    un truc du genre:
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    select mid(machaine, instr(machaine,vbCrLf)) as aPartirLigne2 from matable
    si vbCrLf n'est pas reconnu il est équivalent à chr(13)&chr(10)


  8. #8
    Membre actif
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    191
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juin 2008
    Messages : 191
    Points : 200
    Points
    200
    Par défaut
    Bonjour,

    merci beaucoup vodiem pour la réponse, ça fonctionne très bien! J'arrive en effet avec les fonctions "mid" et "instr" à aller récupérer la 2e ligne d'un champ texte avec succès!

    Maintenant, il ne me reste qu'un petit souci. En fait, c'est que j'aimerais bien afficher dans ma liste déroulante la 2e et la 3e ligne du texte. Or, il semble que par défaut la fonction me retourne tout ce qui se trouve entre le 1er vbcrlf rencontré (soit le début de la 2e ligne) et le suivant (soit la fin de la deuxième ligne). Existe-t-il un moyen de compter les occurrences de vbcrlf afin de pouvoir aller récupérer l'extrait de "machaine" se situant après le 2e vbcrlf par exemple?

    Merci encore,
    al_bert

  9. #9
    Expert confirmé
    Avatar de vodiem
    Homme Profil pro
    Vivre
    Inscrit en
    Avril 2006
    Messages
    2 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Vivre
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2006
    Messages : 2 895
    Points : 4 325
    Points
    4 325
    Par défaut
    tu as plusieurs possibilités:
    .soit tu crées des champs ligne2, ligne3... basé sur Mid() Instr()
    pour avoir la 3 ième linge tu fais partir le Mid à Instr(Instr(txt,vbCrLf)+1,txt, vbCrLf) et ainsi de suite... tu peux extraire entre les vbCrLf avec le Mid() en faisant la différence des positions de vbCrLf. la formulation sera longue surtout qu'il faudra peut être prévoir de rajouter des iif() si les valeurs des positions sont nulle... si cela reste quand même "simple" dans la mesure où tout se situe dans la requete il n'est pas envisageable s'il y a de nombreuses lignes à extraire...
    .soit tu crée une fonction basé sur split() qui renverra la chaine correspondante à la ligne désiré à partir du tableau crée de la chaine découpé par les vbCrLf. c'est plus clair mais peut être un peu plus long à l'exécution et il te faut un module (pb maintenance, distribution)...


  10. #10
    Membre actif
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    191
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juin 2008
    Messages : 191
    Points : 200
    Points
    200
    Par défaut
    Bonjour,

    c'est parfait, ça fonctionne très bien! Comme je n'ai que deux lignes à sélectionner, la solution que vous me proposez en SQL est parfaite ici.

    Encore une fois, merci énormément de votre aide!
    al_bert

  11. #11
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2011
    Messages : 2
    Points : 3
    Points
    3
    Par défaut
    Bonjour à tous,

    J'ai besoin de votre aide concernant un problème du même genre :

    Pour tout dire, j'essaie de copier une chaine qui appartient à la ligne X d'un champ de texte dans un autre.

    Voici un exemple de chaine dans le champ A :
    <DIV class=block id=statistique>
    <UL class=ong>
    <LI class=selected><A>Indicateurs techniques</A></LI></UL>
    <DIV id=content_statistique>
    <TABLE class=tableau00_content id=tab_statistique cellSpacing=0 cellPadding=0 border=0>
    <TBODY>
    <TR class=impaire onmouseover=$hover(event); onmouseout=$_hover(event);>
    <TH class=col1>Valeur intrinsèque</TH>
    <TD>1,50970</TD></TR>
    <TR onmouseover=$hover(event); onmouseout=$_hover(event);>
    <TH class=col1>Valeur temps</TH>
    <TD>0,00</TD></TR>



    Donc comment copier la valeur 1,50970 de la ligne 9 et la coller dans le champ de texte B ?


    Merci

  12. #12
    Membre chevronné
    Inscrit en
    Août 2006
    Messages
    1 588
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 1 588
    Points : 2 178
    Points
    2 178
    Par défaut
    Bonjour,
    pour slaterry cela pourrait se traduire par une requete Mise à jour
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    UPDATE Table1 SET Table1.b = Mid$(Mid$([a],InStr(1,[a],"Valeur intrinsèque")),InStr(1,Mid$([a],InStr(1,[a],"Valeur intrinsèque")),"<TD>")+4,InStr(1,Mid$([a],InStr(1,[a],"Valeur intrinsèque")),"</TD>")-InStr(1,Mid$([a],InStr(1,[a],"Valeur intrinsèque")),"<TD>")-4);
    Table1 devra être remplacer par le nom de la table en cause
    si on considère "Valeur intrinsèque" comme mots clés :
    Mid$(Mid$([a],InStr(1,[a],"Valeur intrinsèque")) retourne la chaine à partir de "Valeur intrinsèque"
    il faut ensuite repérer le premier <TD> et </TD> de cette nouvelle chaine, leur différence de position donnant le nombre de caractères à retourner

  13. #13
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2011
    Messages : 2
    Points : 3
    Points
    3
    Par défaut
    Merci beaucoup helas pour votre aide ainsi que votre rapidité.

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

Discussions similaires

  1. Sélectionner X lignes selon un autre champ
    Par donabut dans le forum Langage SQL
    Réponses: 6
    Dernier message: 10/05/2011, 16h23
  2. Réponses: 2
    Dernier message: 21/06/2007, 13h40
  3. 8i : sql loader et champ texte sur plusieurs lignes
    Par naonedboy dans le forum SQL*Loader
    Réponses: 1
    Dernier message: 23/11/2005, 10h07
  4. [jtable] Champs texte sur pls ligne dans cellule
    Par doudine dans le forum Composants
    Réponses: 8
    Dernier message: 17/11/2005, 12h36
  5. Réponses: 9
    Dernier message: 23/05/2005, 09h35

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