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 :

[DELPHI 2005]TADODATASET et procédure stockée


Sujet :

Bases de données Delphi

  1. #1
    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 : 56
    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 [DELPHI 2005]TADODATASET et procédure stockée
    Bonjour,

    je rencontre un problème que ma recherche sur le forum n'a pas résolu.

    J'utilise un TADODATASET pour exécuter un procédure stockée qui demande un paramêtre.

    Quand je passe le active à true sur le composant, aucune erreur.

    Par contre quand je veux exécuter la procédure depuis le code, j'ai droit à un message d'erreur suivant :
    erreur non spécifiée
    Voici mon code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    procedure tfrmCDG.NPMR_Sales;
    begin
      //format du datetimepicker
      sMois:=formatdatetime('YYYYMM',DTCDG.date);
      with dm_CDG.ADODataSet2.Parameters do begin
       //Passage des paramêtres
       ParamByName('MOIS_FACT').Value:=formatdatetime('YYYYMM',DTCDG.date);
         end;
      //Execution de la requête
      dm_CDG.ADODataSet2.CommandType:=cmdStoredProc;
      dm_CDG.ADODataSet2.Open;
       //Appel de la procédure d'export
      ExportExcel;
    end;
    Voyez-vous quel est le problème ?

  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
    Le AdoDataset est il utilisé par d'autres fonctions ?
    Si oui, un petit Close avant de changer le type de commande serait peut être le bienvenu.
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  3. #3
    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 : 56
    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
    Il n'est pas utilisé mais je vais quand même tenter le close.

  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 : 56
    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
    C'est pas ça..

  5. #5
    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
    Au pire, autant utiliser un composant fait pour : AdoStoredProc.

    Je remarque que les gens ont souvent des problèmes avec les Dataset.
    Peut être que le tout en un, c'est pas terrible ....
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  6. #6
    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 : 56
    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
    Effectivement, je peux essayer avec le TAdoStoredProc..

    A suivre.

  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 : 56
    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
    Ok, j'ai réussi à m'en tirer avec le TADODATASET.

    Le problème semble venir du driver que j'utilisais (MicroSoft for Oracle).
    En le remplacement par le driver Oracle, et en ajoutant en fin de chaîne de connexion ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Extended Properties="PLSQLRSet=1"
    qui permet le renvoi de données, et en modifiant quelque peu les instructions de ma procédure, j'ai finalement réussi à faire ce que je voulais.

    Pour info, en passant par OLEDB, comme c'est le cas maintenant, il faut que l'installation d'oracle sur les postes utilisateurs comprennent les composants OLEDB. (je sais pas si je suis très clair, la fatigue commence à se faire sentir...)

    Ma procédure donne maintenant ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    procedure tfrmCDG.NPMR_Sales;
    begin
      //format du datetimepicker
      sMois:=formatdatetime('YYYYMM',DTCDG.date);
      dm_CDG.ADODataSet2.Close;
      with dm_CDG.ADODataSet2.Parameters do begin
        clear;
        CreateParameter('MOIS_FACT',ftLargeint,pdInput,38,strtoint(sMois));
      end;
      //Execution de la requête
      dm_CDG.ADODataSet2.Open;
      //Appel de la procédure d'export
      ExportExcel;
    end;
    dm_CDG est le nom de mon DataModule, ADODATASET2 mon composant TadoDataset (logique, hein?).

    Dans le composant ADODATASET2 , l'appel de la procédure se fait sur la propriété Commandext de la façon suivante:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    {Call PKG_NPMR.GET_SALES(?)}
    PKG_NPMR est le nom de mon package, GET_SALES le nom de la procédure stockée.
    Le ? signifie qu'un seul paramêtre est attendu en entrée, le curseur de sortie n'étant pas à déclarer.
    Le paramêtre est crée dans la procédure dans Delphi et prend comme valeur la date sélectionnée dans le DateTimePicker.
    La propriété CmdType est sur .

    Bonne soirée à tous,

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

Discussions similaires

  1. [MsSQL 2005] copier une procédure stockée en la renommant
    Par narutobaka dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 20/04/2009, 13h17
  2. Réponses: 2
    Dernier message: 21/03/2008, 16h07
  3. [SQL server 2005][vb.net] procédure stockée, valeur de retour
    Par Ouija33 dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 14/03/2008, 18h33
  4. [SSRS 2005] Utilisé une procédure stockée
    Par bibadom dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 14/06/2007, 16h02
  5. [Delphi][Interbase] pb de procédures stockées
    Par 0rus59 dans le forum Bases de données
    Réponses: 4
    Dernier message: 18/07/2006, 13h53

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