Précédent   Forum des professionnels en informatique > Logiciels > Microsoft Office > Access > Requêtes et SQL.
Requêtes et SQL. Tout ce qui concerne vos questions sur les requêtes et le SQL sous Access se trouve ici.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 23/11/2010, 22h06   #1
Nouveau Membre du Club
 
Homme Alf Cedano
Inscription : septembre 2010
Messages : 71
Détails du profil
Informations personnelles :
Nom : Homme Alf Cedano
Localisation : France, Cher (Centre)

Informations forums :
Inscription : septembre 2010
Messages : 71
Points : 30
Points : 30
Par défaut Ignorer la virgule dans resultat requête avec LIKE

Bonjour.

Veuillez m'excuser si cela a été déjà abordé. J'ai mis plus de 30 minutes à rechercher sans rien trouver.


Supposons que dans une table j'ai un champ qui contient la valeur
AIMER, C'EST VIVRE, AIMER C'EST LA JOIE
et un utilisateur écrit dans la textbox de recherche: AIMER C'EST VIVRE

...C'est à dire, il omet la virgule. Le résultat ne s'affiche pas si j'ai comme code le suivant:

Code :
            strSQL= strSQL & "TitreChant LIKE '*" & (BuscaAcent(strText)) & "*'"
Ce que je voudrais c'est d'ignorer toutes les virgules et qu'il me trouve tous les champs qui contiennent : AIMER C'EST...

J'ai essayé d'omettre le virgule avec ce code, mais rien ne change:

Code :
If InStr(1, strText, ",") > 0 Then strText = Replace(strText, ",", "", 1)
Merci si quelqu'un pourrait m'éclairer.
alfhcg est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 23/11/2010, 22h38   #2
Rédacteur/Modérateur
 
Avatar de User
 
Homme Denis
Développeur informatique
Inscription : août 2004
Messages : 3 200
Détails du profil
Informations personnelles :
Nom : Homme Denis
Âge : 42
Localisation : France

Informations professionnelles :
Activité : Développeur informatique

Informations forums :
Inscription : août 2004
Messages : 3 200
Points : 5 247
Points : 5 247
Salut,

C'est dans la requête (ou dans le sql), sur le champ [TitreChant] qu'il faut utiliser la fonction Replace:

Un peu comme cela :

Code :
strSQL= strSQL & "Replace([TitreChant], ',', '') LIKE '*" & strText & "*'"
Bonne continuation

A+
__________________
Merci de ne pas poster sur mon profil pour des problèmes techniques. Pour celà vous pouvez utiliser le forum ou m'envoyer un mp.

Bon développement !


Mes tutoriels et contributions sur ma page perso:
Ma page personnelle
User est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/11/2010, 00h23   #3
Nouveau Membre du Club
 
Inscription : novembre 2010
Messages : 105
Détails du profil
Informations forums :
Inscription : novembre 2010
Messages : 105
Points : 36
Points : 36
Salut alfhcg, salut User (tiens tiens tiens, comme on se retrouve )

Regarde ça, je m'en suis servi moi aussi: TRES UTILE!!!!
http://grenier.self-access.com/?post...-de-mot-entier

Bonne continuation

Ciao
Cinesra est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/11/2010, 00h37   #4
Nouveau Membre du Club
 
Homme Alf Cedano
Inscription : septembre 2010
Messages : 71
Détails du profil
Informations personnelles :
Nom : Homme Alf Cedano
Localisation : France, Cher (Centre)

Informations forums :
Inscription : septembre 2010
Messages : 71
Points : 30
Points : 30
Merci pour la réponse. Mais cela ne marche pas, le code se plante sur la ligne :

Code :
Set rst = db.OpenRecordset(strSQL)
Erreur n. 3464 : Type de données incompatible...

Le select que j'essaie de passer au recordset est le suivant:

Code :
1
2
3
4
 
SELECT TitreChant 
FROM Chants 
WHERE REPLACE([TitreChant], ',', '') LIKE '*[AÁÀÂÄ][IÍÌÎÏ]m[EÉÈÊË]r c''[EÉÈÊË]st*'
alfhcg est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/11/2010, 15h53   #5
Nouveau Membre du Club
 
Homme Alf Cedano
Inscription : septembre 2010
Messages : 71
Détails du profil
Informations personnelles :
Nom : Homme Alf Cedano
Localisation : France, Cher (Centre)

Informations forums :
Inscription : septembre 2010
Messages : 71
Points : 30
Points : 30
Bonjour Cinesra et merci pour la réponse.

J'ai testé cette fonction, mais elle ne répond pas a mon besoin. Si l'utilisateur envoi comme mot à rechercher:
"AIMER C'EST VIVRE"

Et dans la table il y a un champ qui contient:
"AIMER, C'EST VIVRE, AIMER C'EST LA JOIE"

...La fonction Rechechemot renvoie Faux, alors que c'est tout le contraire: je voudrais que la fonction trouve ce champ, mais il n'est pas trouvé à cause de la virgule qui est après AIMER... Alors comment ignorer cette virgule?
alfhcg est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/11/2010, 17h30   #6
Membre Expert
 
Inscription : janvier 2006
Messages : 1 111
Détails du profil
Informations forums :
Inscription : janvier 2006
Messages : 1 111
Points : 1 093
Points : 1 093
Bonjour,

J'essaierai :
Code :
1
2
3
strSQL="SELECT TitreChant "& _
       "FROM Chants " & _
       "WHERE REPLACE(REPLACE(TitreChant, ',', ''), '''', '') LIKE '*" & replace(replace(strText, "'", ""), ",", "") & "*'"
histoire de se débarrasser de la ' qui risque de poser problème aussi.
__________________
[Access] Les bases du débogage => ici
Kloun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/11/2010, 23h51   #7
Nouveau Membre du Club
 
Homme Alf Cedano
Inscription : septembre 2010
Messages : 71
Détails du profil
Informations personnelles :
Nom : Homme Alf Cedano
Localisation : France, Cher (Centre)

Informations forums :
Inscription : septembre 2010
Messages : 71
Points : 30
Points : 30
Merci pour le réponse.
J'ai essayé comme cela et j'ai la même erreur: 3464.
Je m'avais déjà débarrassée de ' avant d'établir la chaîne strSQL avec:

Code :
strText = Replace(strText, "'", "''")
Voici mon code, qui marche impeccable sans le replace, mais dès que j'essaie avec Replace, c'est la catastrophe...

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
Public Function RechercheChant(strText As String)
On Error GoTo GestionError
 
    Dim strForm As String
    Dim strSQL As String
    Dim dbs As DAO.Database
    Dim intValeur As Integer
    Dim rst As DAO.Recordset
 
    Set dbs = CurrentDb()
    intValeur = 0
    strSQL = "SELECT * FROM Chants WHERE "
 
 
        If Not IsNull(strText) Then
            strText = Replace(strText, "'", "''")
            strSQL = strSQL & "[TitreChant] LIKE '*" & (BuscaAcent(strText)) & "*'"
            intValeur = 1
        End If
 
        If intValeur = 0 Then
            MsgBox "Vous n'avez pas introduit des données à rechercher", vbInformation, "Liturgie Sainte Barbe"
        Else
            strSQL = strSQL & " ORDER BY TitreChant"
            strForm = "frmChantsResultats"
            Set rst = dbs.OpenRecordset(strSQL)
 
            If rst.EOF And rst.BOF Then
                MsgBox "Le chant n'a pas été trouvé avec les mots que vous avez introduits." & vbCrLf _
                & vbCrLf & "Remarque : Pour chercher un chant ce n'est pas nécessaire de saisir tous les mots du titre." _
                & vbCrLf, vbExclamation, "Chant non trouvé"
            Else
                strForm = "frmChantsResultats"
                DoCmd.OpenForm strForm
                Set Form_frmChantsResultats.Recordset = dbs.OpenRecordset(strSQL, , dbReadOnly)
            End If
 
    rst.Close
    Set rst = Nothing
    Set dbs = Nothing
 
        End If
salida:
    Exit Function
 
GestionError:
    Call fnMsgError
    Resume salida
 
End Function
alfhcg est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 09h00   #8
Membre Expert
 
Inscription : janvier 2006
Messages : 1 111
Détails du profil
Informations forums :
Inscription : janvier 2006
Messages : 1 111
Points : 1 093
Points : 1 093
Là, tu t'en débarrasses pas, tu la doubles ...
Et le débug.print, ça donne quoi ?
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
Public Function RechercheChant(strText As String)
On Error GoTo GestionError
 
    Dim strForm As String
    Dim strSQL As String
    Dim dbs As DAO.Database
    Dim intValeur As Integer
    Dim rst As DAO.Recordset
 
    Set dbs = CurrentDb()
    intValeur = 0
    strSQL = "SELECT * FROM Chants WHERE "
 
 
        If Not IsNull(strText) Then
            strText = Replace(strText, "'", "''")
            strSQL = strSQL & "[TitreChant] LIKE '*" & (BuscaAcent(strText)) & "*'"
            intValeur = 1
        End If
 
        If intValeur = 0 Then
            MsgBox "Vous n'avez pas introduit des données à rechercher", vbInformation, "Liturgie Sainte Barbe"
        Else
            strSQL = strSQL & " ORDER BY TitreChant"
debug.print strSQL
            strForm = "frmChantsResultats"
            Set rst = dbs.OpenRecordset(strSQL)
 
            If rst.EOF And rst.BOF Then
                MsgBox "Le chant n'a pas été trouvé avec les mots que vous avez introduits." & vbCrLf _
                & vbCrLf & "Remarque : Pour chercher un chant ce n'est pas nécessaire de saisir tous les mots du titre." _
                & vbCrLf, vbExclamation, "Chant non trouvé"
            Else
                strForm = "frmChantsResultats"
                DoCmd.OpenForm strForm
                Set Form_frmChantsResultats.Recordset = dbs.OpenRecordset(strSQL, , dbReadOnly)
            End If
 
    rst.Close
    Set rst = Nothing
    Set dbs = Nothing
 
        End If
salida:
    Exit Function
 
GestionError:
    Call fnMsgError
    Resume salida
 
End Function
__________________
[Access] Les bases du débogage => ici
Kloun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 11h41   #9
Nouveau Membre du Club
 
Homme Alf Cedano
Inscription : septembre 2010
Messages : 71
Détails du profil
Informations personnelles :
Nom : Homme Alf Cedano
Localisation : France, Cher (Centre)

Informations forums :
Inscription : septembre 2010
Messages : 71
Points : 30
Points : 30
Oui tu as raison, je double le ' pour éviter que la strSQL s'arrête. En effet, je n'ai pas d'intérêt à me débarrasser de ', mais de la virgule. Je crois que pour faire une recherche l'utilisateur n'hésiterait pas à mettre ' , par contre la virgule ce n'est pas sûr qu'il va la taper.

Por le strSQL sans replace le Debug.Print donne cela, si je tape "Aimer c'est vivre". ça marche bien:

Code :
1
2
3
4
SELECT * 
FROM Chants 
WHERE [TitreChant] LIKE '*[AÁÀÂÄ][IÍÌÎÏ]m[EÉÈÊË]r c''[EÉÈÊË]st v[IÍÌÎÏ]vr[EÉÈÊË]*' 
ORDER BY TitreChant
Le Debug.Print avec Replace, me donne:
Code :
1
2
3
4
SELECT * 
FROM Chants 
WHERE Replace([TitreChant], ',', '') LIKE '*[AÁÀÂÄ][IÍÌÎÏ]m[EÉÈÊË]r c''[EÉÈÊË]st v[IÍÌÎÏ]vr[EÉÈÊË]*' 
ORDER BY TitreChant
Cela me donne erreur 3464
alfhcg est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 11h46   #10
Membre Expert
 
Inscription : janvier 2006
Messages : 1 111
Détails du profil
Informations forums :
Inscription : janvier 2006
Messages : 1 111
Points : 1 093
Points : 1 093
Et si tu mets le SQL du debug.print dans une requête, l'erreur n'est pas plus précise ?
__________________
[Access] Les bases du débogage => ici
Kloun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 12h34   #11
Nouveau Membre du Club
 
Homme Alf Cedano
Inscription : septembre 2010
Messages : 71
Détails du profil
Informations personnelles :
Nom : Homme Alf Cedano
Localisation : France, Cher (Centre)

Informations forums :
Inscription : septembre 2010
Messages : 71
Points : 30
Points : 30
Le premier Debug.Print marche bien et le deuxième donne l'erreur:

"Type de données incompatible dans l'expression du critère".
alfhcg est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 13h09   #12
Nouveau Membre du Club
 
Homme Alf Cedano
Inscription : septembre 2010
Messages : 71
Détails du profil
Informations personnelles :
Nom : Homme Alf Cedano
Localisation : France, Cher (Centre)

Informations forums :
Inscription : septembre 2010
Messages : 71
Points : 30
Points : 30
Si à la place du champ TitreChant (string) je mets le champ IdChamp (AutoNuméric) je n'ai pas d'erreur.
alfhcg est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 13h30   #13
Membre Expert
 
Inscription : janvier 2006
Messages : 1 111
Détails du profil
Informations forums :
Inscription : janvier 2006
Messages : 1 111
Points : 1 093
Points : 1 093
Citation:
Envoyé par alfhcg Voir le message
Le premier Debug.Print marche bien et le deuxième donne l'erreur:

"Type de données incompatible dans l'expression du critère".
Je ne suis pas sûr qu'on se comprenne.
Je parle de récupérer le SQL de la fenêtre exécution et de le copier dans la fenêtre SQL d'une nouvelle requête afin de voir ce que ça donne en mode création.
__________________
[Access] Les bases du débogage => ici
Kloun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 14h18   #14
Nouveau Membre du Club
 
Homme Alf Cedano
Inscription : septembre 2010
Messages : 71
Détails du profil
Informations personnelles :
Nom : Homme Alf Cedano
Localisation : France, Cher (Centre)

Informations forums :
Inscription : septembre 2010
Messages : 71
Points : 30
Points : 30
C'est que j'ai fait, j'ai copié le code SQL dans une nouvelle requête access, quand j'essaie de voir la requête en mode feuille de données j'ai une msgbox qui dit:
"Type de données incompatible dans l'expression du critère".
Alors, si dans l'instruction SQL, au lieu de TitreChant (champ type string), je mets IdChant (entier) je n'ai pas d'erreur.
alfhcg est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 14h33   #15
Membre Expert
 
Inscription : janvier 2006
Messages : 1 111
Détails du profil
Informations forums :
Inscription : janvier 2006
Messages : 1 111
Points : 1 093
Points : 1 093

Dans ton code, est ce que tu peux remplace
Code :
1
2
3
            strSQL = strSQL & " ORDER BY TitreChant"
debug.print strSQL
            strForm = "frmChantsResultats"
par
Code :
1
2
3
4
            strSQL = strSQL & " ORDER BY TitreChant"
debug.print strSQL
            strSQL = "SELECT * FROM Chants WHERE [TitreChant] LIKE '*[AÁÀÂÄ][IÍÌÎÏ]m[EÉÈÊË]r*'"
            strForm = "frmChantsResultats"
Et voir si ça passe ?
__________________
[Access] Les bases du débogage => ici
Kloun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 16h50   #16
Nouveau Membre du Club
 
Homme Alf Cedano
Inscription : septembre 2010
Messages : 71
Détails du profil
Informations personnelles :
Nom : Homme Alf Cedano
Localisation : France, Cher (Centre)

Informations forums :
Inscription : septembre 2010
Messages : 71
Points : 30
Points : 30
Avec:
Code :
1
2
3
4
            strSQL = strSQL & " ORDER BY TitreChant"
            Debug.Print strSQL
            strSQL = "SELECT * FROM Chants WHERE [TitreChant] LIKE '*[AÁÀÂÄ][IÍÌÎÏ]m[EÉÈÊË]r*'"
            strForm = "frmChantsResultats"
J'obtiens tous les chants qui contiennent le mot "Aimer"
alfhcg est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/11/2010, 10h06   #17
Membre Expert
 
Inscription : janvier 2006
Messages : 1 111
Détails du profil
Informations forums :
Inscription : janvier 2006
Messages : 1 111
Points : 1 093
Points : 1 093
Allons un peu plus loin :
Code :
1
2
3
4
            strSQL = strSQL & " ORDER BY TitreChant"
            Debug.Print strSQL
            strSQL = "SELECT * FROM Chants WHERE [TitreChant] LIKE '*[AÁÀÂÄ][IÍÌÎÏ]m[EÉÈÊË]r c''[EÉÈÊË]st*'"
            strForm = "frmChantsResultats"
__________________
[Access] Les bases du débogage => ici
Kloun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/11/2010, 22h34   #18
Nouveau Membre du Club
 
Homme Alf Cedano
Inscription : septembre 2010
Messages : 71
Détails du profil
Informations personnelles :
Nom : Homme Alf Cedano
Localisation : France, Cher (Centre)

Informations forums :
Inscription : septembre 2010
Messages : 71
Points : 30
Points : 30
Là il me trouve le chant. Mais comment faire pour qu'il prenne la valeur à rechercher d'une variable?

Merci.
alfhcg est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/11/2010, 10h19   #19
Membre Expert
 
Inscription : janvier 2006
Messages : 1 111
Détails du profil
Informations forums :
Inscription : janvier 2006
Messages : 1 111
Points : 1 093
Points : 1 093
Dernier test :
Code :
1
2
3
4
            strSQL = strSQL & " ORDER BY TitreChant"
            Debug.Print strSQL
            strSQL = "SELECT * FROM Chants WHERE [TitreChant] LIKE '*[AÁÀÂÄ][IÍÌÎÏ]m[EÉÈÊË]r c''[EÉÈÊË]st*'  ORDER BY TitreChant"
            strForm = "frmChantsResultats"
Là, on a le SQL d'origine normalement.
__________________
[Access] Les bases du débogage => ici
Kloun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/11/2010, 15h16   #20
Nouveau Membre du Club
 
Homme Alf Cedano
Inscription : septembre 2010
Messages : 71
Détails du profil
Informations personnelles :
Nom : Homme Alf Cedano
Localisation : France, Cher (Centre)

Informations forums :
Inscription : septembre 2010
Messages : 71
Points : 30
Points : 30
Il me trouve le chant:
AIMER, C'EST VIVRE, AIMER C'EST LA JOIE

Mais il ne trouve pas les chants suivants qui commencent par le même mot:

AIMER, C'EST TOUT DONNER
AIMER, C'EST VIVRE
alfhcg est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 09h53.


 
 
 
 
Partenaires

Hébergement Web