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

Macros et VBA Excel Discussion :

Erreur lors de la lecture des données d'un Tableau Structuré avec du SQL


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Ingénieur Données Maintenance
    Inscrit en
    Novembre 2024
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Ingénieur Données Maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2024
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Erreur lors de la lecture des données d'un Tableau Structuré avec du SQL
    Bonjour,

    N'étant pas développeur professionnellement mais ayant régulièrement besoin d'outils plus ou moins avancés, je travaille régulièrement avec des tableaux structurés et des sources de données SQL Server (j'ai la certification SQL Server, et je fais du SQL depuis 24 ans)

    Ayant découvert le module TS de Laurent OTT (https://laurent-ott.developpez.com/t...ux-Structures/), je m'en sers de plus en plus pour éviter d'alourdir mon code avec des approximations ou des structures inutiles.

    Dans ma situation actuelle, j'ai un tableau structuré qui est alimenté manuellement depuis un export d'un autre fichier (je verrais comment gérer cette partie après)
    Une fois les données dans mon tableau (deux colonnes de texte), je découpe la seconde chaine de texte en 4 segments (XXX-XXX-XXX-XXX) avec un split et je viens alimenter les 4 autres colonnes de mon tableau avec cela.
    A partir de là, je dois extraire la valeur maximale du segment 4, groupé selon les 3 autres segments.
    En SQL, on a donc :
    select s1, s2, s3, MAX(s4) from TS group by s1, s2, s3

    Le souci, c'est que je n'arrive à rien : dès que je lance la fonction TS_RequeteSQL qui appelle la fonction TS_ExecuterSQL, j'ai un message "Erreur d'exécution -2147467259 (80004005) : Mise à jour impossible. La base de données ou l'objet est en lecture seule".
    Sauf que rien n'est en lecture seule, et ma requête ne fait qu'un select. J'ai beau regarder le code, je ne vois pas d'erreur et même en forçant IMEX=2, cela ne fonctionne pas.
    J'avoue être perplexe, car en revanche, je peux copier/coller des colonnes entre les deux tableaux avec la fonction TS_CopierValeurColonne. Donc, je ne suis pas en lecture seule.

    Ai-je raté une option de mon fichier ou un complément pour permettre les modifications ?

  2. #2
    Expert éminent sénior

    Profil pro
    Conseil, Formation, Développement - Indépendant
    Inscrit en
    Février 2010
    Messages
    8 528
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Conseil, Formation, Développement - Indépendant

    Informations forums :
    Inscription : Février 2010
    Messages : 8 528
    Points : 16 468
    Points
    16 468
    Par défaut
    Bonjour

    Pourquoi ne pas utiliser PowerQuery, intégré à Excel, où on peut faire équivalent sans coder en VBA
    Chris
    PowerQuery existe depuis plus de 13 ans, est totalement intégré à Excel 2016 &+. Utilisez-le !

    Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson.
    Confucius

    ----------------------------------------------------------------------------------------------
    En cas de résolution, n'hésitez pas cliquer sur c'est toujours apprécié...

  3. #3
    Membre expérimenté
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 862
    Points : 1 604
    Points
    1 604
    Billets dans le blog
    2
    Par défaut
    Bonjour,

    La proposition de Chris est à prendre en considération, c'est une solution qu'il peut être intéressant à envisager

    Sinon, concernant le module de classe de Laurent Ott, je ne le connais pas mais en lisant la page dont vous avez fourni le lien, il semblerait que les exemples ne fonctionnent pas avec du SQL complet mais seulement la fin de la requête SQL
    https://laurent-ott.developpez.com/t...ctures/#LXII-B
    Lisez les exemples et essayez d'adapter à votre requête

Discussions similaires

  1. Réponses: 1
    Dernier message: 02/07/2006, 12h42
  2. erreur lors de l'envoie de donné via les socket.
    Par poporiding dans le forum C++
    Réponses: 1
    Dernier message: 23/05/2006, 15h23
  3. Erreur lors de l' utilisation des objets ADO
    Par aityahia dans le forum Bases de données
    Réponses: 10
    Dernier message: 24/03/2006, 14h46
  4. Erreur lors de la lecture d'un blob
    Par guille007 dans le forum DB2
    Réponses: 3
    Dernier message: 07/03/2006, 17h37
  5. Eviter les erreurs lors de l'utilisation des compo Tsocket
    Par Coussati dans le forum Composants VCL
    Réponses: 5
    Dernier message: 01/02/2006, 20h14

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