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

Accès aux données Discussion :

Utiliser Enterprise Library avec Oracle Stored Procedure


Sujet :

Accès aux données

  1. #1
    Membre à l'essai
    Inscrit en
    Octobre 2004
    Messages
    28
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 28
    Points : 19
    Points
    19
    Par défaut Utiliser Enterprise Library avec Oracle Stored Procedure
    Salut,

    je souhaite appeler une Oracle stored procedure d'un package avec un Number et un cursor en parametre pour cette sp.

    J'utilise Enterprise Library June 2005 - .Net 1.1 et Oracle 10g
    Voici mon bout de code qui pose probleme

    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
     
    Database db = DatabaseFactory.CreateDatabase(sDatabaseInstance);
    DBCommandWrapper dbCommandWrapper = db.GetStoredProcCommandWrapper("phone_directory_pkg.sp_Emp_Directory_GetEmpInfo");
     
     
    // Parameter in.
    OracleParameter par_in = new OracleParameter("p_PersonIdNo", OracleType.Int32, 30000, ParameterDirection.Input, false, 0, 0, String.Empty, DataRowVersion.Default, Convert.ToInt32(this.txtPidNumber.Text.Trim()));
     
    // Parameter out.
    OracleParameter par_out = new OracleParameter("emp_ref_cursor", OracleType.Cursor, 30000, ParameterDirection.Output, true, 0, 0, String.Empty, DataRowVersion.Default, Convert.DBNull);
     
    dbCommandWrapper.AddInParameter(par_in.ParameterName, par_in.DbType, par_in.Value);
    dbCommandWrapper.AddOutParameter(par_out.ParameterName, par_out.DbType, par_out.Size);
     
    DataSet ds = db.ExecuteDataSet(dbCommandWrapper);
    Jai cette erreur une fois le code executé:

    Error Message: ORA-06550: line 1, column 7:
    PLS-00306: wrong number or types of arguments in call to 'SP_EMP_DIRECTORY_GETEMPINFO'
    ORA-06550: line 1, column 7:
    PL/SQL: Statement ignored
    La procedure est declaré comme ceci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    TYPE employee_type IS REF CURSOR;
     
    PROCEDURE sp_Emp_Directory_GetEmpInfo(p_PersonIdNo IN NUMBER, emp_ref_cursor OUT employee_type);
    Quelqu'un a déjà eu cette erreur?
    Merci d'avance pour l'aide
    a+

  2. #2
    Membre à l'essai
    Inscrit en
    Octobre 2004
    Messages
    28
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 28
    Points : 19
    Points
    19
    Par défaut
    En fait, peut etre que ma question devrait être tout simplement, peut on utiliser l'enterprise Library June 2005 pour appeler/utiliser des procedure stockées sur Oracle 10g avec un ref cursor en Output?

    Personne n'a déjà testé?

Discussions similaires

  1. Peux-t-on utiliser un SqlDataSource avec Oracle(odt)?
    Par cyril dans le forum Accès aux données
    Réponses: 3
    Dernier message: 02/12/2008, 17h54
  2. Peut-on utiliser les DataSet avec Oracle ?
    Par etoile_de_vie dans le forum C#
    Réponses: 19
    Dernier message: 28/04/2008, 16h13
  3. [Oracle] Stored Procedures Variable
    Par elnfrancois dans le forum SQL
    Réponses: 2
    Dernier message: 11/09/2007, 16h34
  4. utilisation enterprise manager avec 10GR1.
    Par ylarvor dans le forum Installation
    Réponses: 2
    Dernier message: 01/08/2007, 12h25
  5. [sql 200] Problème avec une stored procedure
    Par marc_dd dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 01/12/2006, 15h11

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