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

Access Discussion :

Prb de longueur dans STRING


Sujet :

Access

  1. #1
    Membre régulier

    Inscrit en
    Septembre 2004
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Septembre 2004
    Messages : 84
    Points : 81
    Points
    81
    Par défaut Prb de longueur dans STRING
    Bonjour à tous !
    Je veux initialiser une chaîne de caratères qui contient une requête SQL à passer à un DoCmd.RunSQL

    Mais voilà, ma chaîne est d'une longueur supérieur à 255 caratères et ma variable de type STRING ne peut apparement pas contenir + de 254 caratères.
    Pourant dans l'aide de Access 2003, il est marqué :
    String
    (longueur variable) 10 octets + longueur de la chaîne 0 à environ 2 milliards
    Mais aussi :
    String
    (longueur fixe) Longueur de la chaîne 1 à environ 65 400
    Comment faire une déclaration de variable de type String avec une longueur variable et profiter de ces 2 milliard de caractères ??????

    Merci !
    [/quote]

  2. #2
    Expert éminent sénior

    Avatar de Tofalu
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2004
    Messages
    9 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2004
    Messages : 9 501
    Points : 32 311
    Points
    32 311
    Par défaut
    Dim Variable As String

    sera largement suffisant Et par défaut, elle est à longueur variable

  3. #3
    Membre régulier

    Inscrit en
    Septembre 2004
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Septembre 2004
    Messages : 84
    Points : 81
    Points
    81
    Par défaut
    Tu penses bien que ça c'est déjà fait !!!
    D'autant plus que je mets systématiquement Option Explicit en haut de chaque module!!

    Apparement, je ne suis pas le seul à avoir ce type de prb :
    http://www.developpez.net/forums/vie...tring+longueur

  4. #4
    Expert éminent sénior

    Avatar de Tofalu
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2004
    Messages
    9 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2004
    Messages : 9 501
    Points : 32 311
    Points
    32 311
    Par défaut
    Attention c'est la propriété RowSource qui est limité, pas la variable String !!!

  5. #5
    Membre régulier

    Inscrit en
    Septembre 2004
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Septembre 2004
    Messages : 84
    Points : 81
    Points
    81
    Par défaut
    Alors pourquoi dans la fenêtre Variables locales, je n'ai pas ma chaîne en entière mais bien tronquée à 254 caractères ?

  6. #6
    Membre régulier

    Inscrit en
    Septembre 2004
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Septembre 2004
    Messages : 84
    Points : 81
    Points
    81
    Par défaut
    Ah ben voui t'as raison, si je fais un msgbox strSQL, j'ai bien ma requête en entière.
    Du coup comment faire ???
    Va falloir que je scinde en 2 ma requête ?
    Une avec INSERT et une autre avec UPDATE ?
    C'est du délire !!!

  7. #7
    Expert éminent sénior

    Avatar de Tofalu
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2004
    Messages
    9 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2004
    Messages : 9 501
    Points : 32 311
    Points
    32 311
    Par défaut
    C'est pourquoi faire ?

  8. #8
    Membre averti

    Profil pro
    Inscrit en
    Mai 2004
    Messages
    236
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 236
    Points : 310
    Points
    310
    Par défaut
    Tu peux peut-être enregistrer la requête via DAO pour contourner le problème.

  9. #9
    Expert confirmé

    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 419
    Points : 4 297
    Points
    4 297
    Par défaut
    je ne vois pas le problème
    spécifications requêtes
    Nombre de caractères d'une instruction SQL environ 64 000
    Les chaînes de longueur variable peuvent contenir environ 2 milliards (2^31) de caractères.
    as tu essayé d'ajouter une querydef avec ton code et de la lancer ?
    Elle est pas belle la vie ?

  10. #10
    Membre régulier

    Inscrit en
    Septembre 2004
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Septembre 2004
    Messages : 84
    Points : 81
    Points
    81
    Par défaut
    Voilà mon code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
                strSQL = "INSERT INTO " & Mid(strNomFichier, 1, InStrRev(strNomFichier, ".")) & " (CLIIDCLI, CLICODCL, CLINOMBR, CLISIGCA, CLICALLE, CLITELEF, CLIDIRER, CLICODPO, CLICIUPR, CLINACIO, CLIDMOAD, CLICOPFA, CLIFILIA, CLITIPCL, CLIFALTA, CLIFBAJA, CLINUREL, CLIRAMA, CLICUENT, CLICARTE, CLIFACTU, CLISBAJA, "
                strSQL = strSQL & "CLITIIVA, CLILIMCR, CLISIGCE, CLINIF12, CLIATENC, CLILMIVA) "
                strSQL = strSQL & "VALUES (""" & strLigne(1) & """ , """ & strLigne(2) & """ , """ & strLigne(3) & """ , """ & strLigne(4) & """ , """ & strLigne(5) & """ , """ & strLigne(6) & """ , """ & strLigne(7) & """ , """ & strLigne(8) & """ , """ & strLigne(9) & """ , """ & strLigne(10) & """ , """ & strLigne(11) & """ , """ & strLigne(12) & """ , """ & strLigne(13) & """ , """
                strSQL = strSQL & strLigne(14) & """ , """ & strLigne(15) & """ , """ & strLigne(16) & """ , """ & strLigne(17) & """ , """ & strLigne(18) & """ , """ & strLigne(19) & """ , """ & strLigne(20) & """ , """ & strLigne(21) & """ , """ & strLigne(22) & """ , """ & strLigne(23) & """ , """ & strLigne(24) & ""","""
                strSQL = strSQL & strLigne(25) & """ , """ & strLigne(26) & """ , """ & strLigne(27) & """ ,""" & strLigne(28) & """);"
                MsgBox strSQL
     
                DoCmd.RunSQL strSQL
    Dans la MsgBox, j'ai bien ma requête en entière, mais pas dans la fenêtre des variables locales.

  11. #11
    Expert confirmé

    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 419
    Points : 4 297
    Points
    4 297
    Par défaut
    essaye d'abord MsgBox strSQL len(stsql)
    tu verras bien
    ensuite mets strsql en variant réessaye
    Elle est pas belle la vie ?

  12. #12
    Membre averti

    Profil pro
    Inscrit en
    Mai 2004
    Messages
    236
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 236
    Points : 310
    Points
    310
    Par défaut
    j'ai l'impression que ta requête est erronée à cause des " " " qui entourent tes zones de textes. Essayes ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    strSQL = "INSERT INTO " & Mid(strNomFichier, 1, InStrRev(strNomFichier, ".")) & " (CLIIDCLI, CLICODCL, CLINOMBR, CLISIGCA, CLICALLE, CLITELEF, CLIDIRER, CLICODPO, CLICIUPR, CLINACIO, CLIDMOAD, CLICOPFA, CLIFILIA, CLITIPCL, CLIFALTA, CLIFBAJA, CLINUREL, CLIRAMA, CLICUENT, CLICARTE, CLIFACTU, CLISBAJA, " 
                strSQL = strSQL & "CLITIIVA, CLILIMCR, CLISIGCE, CLINIF12, CLIATENC, CLILMIVA) " 
                strSQL = strSQL & "VALUES (" ' " & strLigne(1) & "'" , "'" & strLigne(2) & "'" , "'" & strLigne(3) & "'" , "'" & strLigne(4) & "'" , "'" & strLigne(5) & "'" , "'" & strLigne(6) & "'" , "'" & strLigne(7) & "'" , "'" & strLigne(8) & "'" , "'" & strLigne(9) & "'" , "'" & strLigne(10) & "'" , "'" & strLigne(11) & "'" , "'" & strLigne(12) & "'" , "'" & strLigne(13) & "'" , "'" 
                strSQL = strSQL & strLigne(14) & "'" , "'" & strLigne(15) & "'" , "'" & strLigne(16) & "'" , "'" & strLigne(17) & "'" , "'" & strLigne(18) & "'" , "'" & strLigne(19) & "'" , "'" & strLigne(20) & "'" , "'" & strLigne(21) & "'" , "'" & strLigne(22) & "'" , "'" & strLigne(23) & "'" , "'" & strLigne(24) & "'","'" 
                strSQL = strSQL & strLigne(25) & "'" , "'" & strLigne(26) & "'" , "'" & strLigne(27) & "'" ,"'" & strLigne(28) & "'");"

  13. #13
    Expert éminent sénior

    Avatar de Tofalu
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2004
    Messages
    9 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2004
    Messages : 9 501
    Points : 32 311
    Points
    32 311
    Par défaut
    Oui, car la fenêtre d'espion tronque une partie. Mais ta variable contient bien tout. Donc pas d'erreur à priori

    Un truc me chiffone .. tous tes champs sont de type texte ?

  14. #14
    Membre régulier

    Inscrit en
    Septembre 2004
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Septembre 2004
    Messages : 84
    Points : 81
    Points
    81
    Par défaut
    Oui ils sont tous de type texte.
    Voici le message d'erreur lorsque le pas ç pas passe sur DoCmd.RunSQL strSQL :

    Erreur d'éxécution 3450
    Erreur de syntaxe dans la requête.
    La clause de la requête est incomplète.
    Si je clique sur aide :
    Erreur de syntaxe dans la requête. La clause de la requête est incomplète. (Erreur 3450)
    Cette erreur se produit lorsque vous essayez de sauvegarder une requête enregistrée (vue ouprocédure).

  15. #15
    Membre régulier

    Inscrit en
    Septembre 2004
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Septembre 2004
    Messages : 84
    Points : 81
    Points
    81
    Par défaut
    Laisse tomber, je suis (encore) un neuneu de bas étages !!

    J'ai pas construit mon nom de table comme il faut :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Mid(strNomFichier, 1, InStrRev(strNomFichier, "."))
    Il faut :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Mid(strNomFichier, 1, InStrRev(strNomFichier, ".") - 1)
    Sinon, le nom de ma table comprend un point (je récupére le nom du fichier comme nom de ma table).
    Maintenant, ça fonctionne bien.

    Merci à vous tous d'avoir essayé de trouver la solution, pardonnez moi d'avoir pris sur votre temps si précieux pour des clopinettes !

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

Discussions similaires

  1. [initialisation et valeur] valeur dans String[]
    Par okoax dans le forum Langage
    Réponses: 2
    Dernier message: 18/01/2006, 11h34
  2. [Débutant(e)] écriture Majuscule Minuscule dans String
    Par florantine dans le forum Langage
    Réponses: 4
    Dernier message: 23/11/2005, 17h34
  3. Valeur hexadecimale dans String -> Long
    Par Stol dans le forum Langage
    Réponses: 2
    Dernier message: 25/03/2005, 16h31
  4. Problème de copie de string dans string
    Par kazarn dans le forum SL & STL
    Réponses: 17
    Dernier message: 15/03/2005, 18h35
  5. Prb de fonctionnement dans SaveDialog avecInitialDir
    Par boyerf dans le forum Composants VCL
    Réponses: 4
    Dernier message: 12/12/2002, 21h46

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