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

Bases de données Delphi Discussion :

Accès non autorisé à l'exécution d'une procédure stockée


Sujet :

Bases de données Delphi

  1. #1
    Membre à l'essai
    Inscrit en
    Janvier 2006
    Messages
    37
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 37
    Points : 19
    Points
    19
    Par défaut Accès non autorisé à l'exécution d'une procédure stockée
    Bonjour,

    Je voudrais exécuter une procédure stockée et récupérer les paramètres de sortie dans un clientDataset.
    J'ai les erreurs suivantes à l'exécution de mon code

    Droits SQL insuffisants pour l'opération.
    No permission for execute access to PROCEDURE MA_PROCEDURE


    ou

    Impossible d'effectuer cette opéraiton sur un ensemble de données fermé

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
     
      procTemp := TStoredProc.create(application);
      procTemp.DatabaseName := MaBase.DatabaseName;
     
        with procTemp do
        try
        begin
          StoredProcName := 'MA_PROCEDURE';
          Params.Clear;
          Params.CreateParam(ftDate,'DATECH',ptInput);
     
          Params.CreateParam(ftString,'TYPDEB',ptOutput);
          Params.CreateParam(ftString,'NOFACT',ptOutput);
     
         Prepare;
         ExecProc;
     
    if procTemp.RecordCount > 0 then // --> erreur à l'exécution
          begin
    ...
    Que faut-il modifier dans le code? ou au niveau de la définition de la procédure pour pouvoir l'exécuter?

    Merci de votre aide.

  2. #2
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Ton problème doit venir du fait que tu n'as pas les droits suffisants sur le serveur de base de données, il faut que tu vois cela avec ton adminitrateur de base de données.

  3. #3
    Membre à l'essai
    Inscrit en
    Janvier 2006
    Messages
    37
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 37
    Points : 19
    Points
    19
    Par défaut
    C'est ce que je soupçonnais au début, mais j'ai bien l'accès en exécution au moins en mode administrateur dans le DDL de ma procédure:

    GRANT EXECUTE ON PROCEDURE MA_PROCEDURE TO ADMIN;

    En mode admin, j'ai l'erreur :
    Impossible d'effectuer cette opération sur un ensemble de données fermé

    Il faut ouvrir la procédure en exécution?

  4. #4
    Membre expérimenté
    Avatar de Frank
    Homme Profil pro
    Chef de projet Informatique
    Inscrit en
    Avril 2002
    Messages
    1 095
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Chef de projet Informatique
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Avril 2002
    Messages : 1 095
    Points : 1 392
    Points
    1 392
    Par défaut
    As tu fais un grant sur les tables utilisées dans ta procédure ?

  5. #5
    Membre à l'essai
    Inscrit en
    Janvier 2006
    Messages
    37
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 37
    Points : 19
    Points
    19
    Par défaut
    Oui, je confirme, les grant sur les tables sont définis automatiquement (je suis sous Interbase) ...

  6. #6
    Membre à l'essai
    Inscrit en
    Janvier 2006
    Messages
    37
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 37
    Points : 19
    Points
    19
    Par défaut [Resolu]
    Ca ne venait pas des droits d'accès.
    J'ai modifié le code pour récupérer le résultat de la procédure stockée dans une requête.
    Merci
    Je posterai un exemple d'une solution qui fonctionne plus tard.

  7. #7
    Membre expérimenté
    Avatar de Frank
    Homme Profil pro
    Chef de projet Informatique
    Inscrit en
    Avril 2002
    Messages
    1 095
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Chef de projet Informatique
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Avril 2002
    Messages : 1 095
    Points : 1 392
    Points
    1 392
    Par défaut Re: [Resolu]
    Citation Envoyé par celine33
    Ca ne venait pas des droits d'accès.
    J'ai modifié le code pour récupérer le résultat de la procédure stockée dans une requête.
    Merci
    Je posterai un exemple d'une solution qui fonctionne plus tard.
    Super!
    Par contre, pour le , cherches le bouton qui ressemble à celui-ci.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 02/11/2009, 16h22
  2. Réponses: 2
    Dernier message: 30/09/2008, 14h49
  3. Réponses: 0
    Dernier message: 30/09/2008, 01h14
  4. Erreur d'Exécution d'une procédure stockée
    Par h.Madjid dans le forum SQL
    Réponses: 1
    Dernier message: 05/09/2007, 19h34
  5. Exécution d'une procédure stockée dans Sql
    Par Pascalp dans le forum Access
    Réponses: 4
    Dernier message: 01/09/2006, 11h47

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