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

C# Discussion :

Procedure oracle : Forcer un parametre de type number à null


Sujet :

C#

  1. #1
    Membre à l'essai
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2007
    Messages
    25
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2007
    Messages : 25
    Points : 11
    Points
    11
    Par défaut Procedure oracle : Forcer un parametre de type number à null
    Bonjour,

    j'utilise une procedure oracle pour insérer des données dans une table de la BD..

    procedure p_cre_execu(pc_proje in varchar2,
    pc_tra_id in varchar2,
    pc_envir in varchar2 := null,
    pc_statu in varchar2 := null,
    pd_date_soumi in date := null,
    pd_date_deman in date := null,
    pc_param in varchar2 := null,
    pc_cle_uniqu_execu in varchar2 := null,
    pc_prior in number := null,
    pc_queue in varchar2 := null,
    pc_descr_execu in varchar2 := null,
    pc_val_param_xml in varchar2 := null,
    pn_exe_no out number);

    Il y a des paramètres qui peuvent être null.

    Le problème que j'ai est comment mettre le paramètre pc_prior qui est de type number a null?

    voici l'appel à la procedure :
    CreerExecution(requete.PROJET,
    requete.TRA_ID,
    requete.TRA_ENVIR,
    requete.EXE_STATU,
    requete.IsEXE_DH_SOUMINull() ? DateTime.Now : requete.EXE_DH_SOUMI,
    DateTime.Now,
    requete.IsEXE_PARAMNull() ? string.Empty : requete.EXE_PARAM,
    requete.IsEXE_CLE_UNIQU_EXECUNull() ? string.Empty : requete.EXE_CLE_UNIQU_EXECU,
    0,
    requete.IsEXE_QUEUENull() ? string.Empty : requete.EXE_QUEUE,requete.EXE_DESCR_EXECU, requete.IsEXE_VAL_PARAM_XMLNull() ? string.Empty : requete.EXE_VAL_PARAM_XML);


    Merci d'avance

  2. #2
    Membre émérite Avatar de Guulh
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    2 160
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2007
    Messages : 2 160
    Points : 2 925
    Points
    2 925
    Par défaut
    Je sais pas si la méthode CreerExecution est générée par un outil ou si c'est toi qui l'a écrite; en tous cas, en .Net, pour affecter la valeur null à un paramètre de proc / stock : requête paramétrée, il faut utiliser DBNull.Value (ou null, plus simplement).
    ಠ_ಠ

  3. #3
    Membre à l'essai
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2007
    Messages
    25
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2007
    Messages : 25
    Points : 11
    Points
    11
    Par défaut
    En fait, j'utilise les tableadapter. Donc j'ajoute a mon TableAdapter une procédure stocké a partir de l'assitant de création de requête..

    voici la méthode CreerRequeteTravail

    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
     
    public int CreerRequeteTravail(string projet, 							string identifiantChaine, 
    			string envir, 
    			string statut, 
    			DateTime dateSoumission, 
    			DateTime dateDemande, 
    			string parametres, 
    			string cle,
    			int priorite,
    			string queue,
    		             string desc,
    			string paramXML)
    {
        Journal.JournaliserMethode(GetType().Name, System.Reflection.MethodBase.GetCurrentMethod().Name);
     
    using (XAI_EXECUTION_V_TRAVAILTableAdapter tableAdapter = new XAI_EXECUTION_V_TRAVAILTableAdapter())
    {
    tableAdapter.Connection = _connexion.OracleConnexion;
    object numeroExecution = tableAdapter.CreerRequeteTravail(projet, 
    						identifiantChaine, 
    						envir, 
    						statut, 
    						dateSoumission, 							dateDemande, 
    						parametres,
    						cle,
    						priorite,
    						queue,
    						desc,
    						paramXML);
     
    return (int)numeroExecution;
    }
    }
    Dans la description de la procedure pc_prior est de type number et moi je ne veux rien saisir dans ce paramètre.

  4. #4
    Membre à l'essai
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2007
    Messages
    25
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2007
    Messages : 25
    Points : 11
    Points
    11
    Par défaut
    Est ce que qu'un a une idée??

    Merci

  5. #5
    Rédacteur
    Avatar de jsd03
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Août 2008
    Messages
    1 221
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information

    Informations forums :
    Inscription : Août 2008
    Messages : 1 221
    Points : 6 506
    Points
    6 506
    Par défaut
    Juste un petit truc :

    Pour donner une valeur null à un champs Oracle il ne faut pas le faire comme tu le fais avec ":=" mais en utilisant DEFAULT NULL :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    procedure p_cre_execu(pc_proje in varchar2,
    pc_tra_id in varchar2,
    pc_envir in varchar2 DEFAULT NULL,
    pc_statu in varchar2 DEFAULT NULL,
    pd_date_soumi in date DEFAULT NULL,
    pd_date_deman in date  DEFAULT NULL,
    pc_param in varchar2 DEFAULT NULL,
    pc_cle_uniqu_execu in varchar2  DEFAULT NULL,
    pc_prior in number DEFAULT NULL,
    pc_queue in varchar2  DEFAULT NULL,
    pc_descr_execu in varchar2  DEFAULT NULL,
    pc_val_param_xml in varchar2  DEFAULT NULL,
    pn_exe_no out number);
    Du coup tu n'es plus obligé de donner une valeur au champs qui ont pour valeur par défaut null.
    Google est ton ami mais ton voisin aussi

    Modérateur BI - Responsable Talend
    Mes tutoriels - FAQ Talend - FAQ SQL*Plus

    Avant toute chose : lire le mode d'emploi du forum et ses règles.
    Suivez @Developpez sur twitter !

Discussions similaires

  1. Réponses: 5
    Dernier message: 22/01/2015, 11h59
  2. requête Oracle sur type NUMBER
    Par Cram_N7 dans le forum JDBC
    Réponses: 2
    Dernier message: 11/05/2009, 08h48
  3. Réponses: 0
    Dernier message: 11/11/2008, 10h30
  4. Réponses: 1
    Dernier message: 19/08/2008, 07h40
  5. Variable Oracle de type number
    Par marti dans le forum Oracle
    Réponses: 1
    Dernier message: 16/08/2005, 11h04

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