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 :

La valeur ne pas être null. [Débutant]


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2019
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Togo

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

    Informations forums :
    Inscription : Septembre 2019
    Messages : 22
    Par défaut La valeur ne pas être null.
    Salut. Je suis un débutant en C#. j'essaie de renseigner un formulaire de saisi pour l'enregistrer dans ma base de données Sql. Quand je veux enregistrer les valeurs j'ai l'erreur *"La valeur ne pas être null."* Voici le 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
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
     
    using System;
    using System.Collections.Generic;
    using System.Data;
    using System.Data.SqlClient;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using System.Windows;
    using System.Windows.Controls;
    using System.Windows.Data;
    using System.Windows.Documents;
    using System.Windows.Input;
    using System.Windows.Media;
    using System.Windows.Media.Imaging;
    using System.Windows.Shapes;
     
    namespace CsMac
    {
        /// <summary>
        /// Logique d'interaction pour Window3.xaml
        /// </summary>
        public partial class Window3 : Window
        {
            private SqlDataAdapter dataAdapter;
            private DataSet loginCredentials;
     
            public Window3()
            {
                InitializeComponent();
            }
     
            private void Enr_Click(object sender, RoutedEventArgs e)
            {
                SqlConnection sqlcon = new SqlConnection("Data Source=TGOCLC0H5YV0\\SQLSERVER;Initial Catalog=CsMac; Trusted_Connection=True;");
                try
                {
                    if (sqlcon.State == ConnectionState.Closed)
                        sqlcon.Open();
                    string req = "INSERT INTO Demandes(CodeDmd, NomDemandeur, ServiceDemandeur, DesignationCs, Qte, PU, Total, DateEtHeure, Etat, Observation) VALUES (@CodeDmd, @NomDemandeur, @ServiceDemandeur, @DesignationCs, @Qte, @PU, @Total, @DateEtHeure, @Etat, @Observation)";
                       SqlCommand cmd = new SqlCommand(req, sqlcon);
                    dataAdapter = new SqlDataAdapter(cmd);
                    dataAdapter.Fill(loginCredentials);
                    cmd.CommandType = CommandType.Text;
                    cmd.Parameters.Add(new SqlParameter("@CodeCmd", txtcode.Text));
                    cmd.Parameters.Add(new SqlParameter("@NomDemandeur", txtnom.Text));
                    cmd.Parameters.Add(new SqlParameter("@ServiceDemandeur", txtservice.Text));
                    cmd.Parameters.Add(new SqlParameter("@DesignationCs", txtdesignation.Text));
                    cmd.Parameters.Add(new SqlParameter("@Qte", txtqte.Text));
                    cmd.Parameters.Add(new SqlParameter("@PU", txtpu.Text));
                    cmd.Parameters.Add(new SqlParameter("@Total", txttotal.Text));
                    cmd.Parameters.Add(new SqlParameter("@DateEtHeure", txtdate.Text));
                    cmd.Parameters.Add(new SqlParameter("@Etat", txtetat.Text));
                    cmd.Parameters.Add(new SqlParameter("@Observation", txtobservation.Text));
     
                    cmd.ExecuteNonQuery();
                    MessageBox.Show("Demande enregistrée.");
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message);
                }
                finally
                {
                    sqlcon.Close();
                }
     
            }
        }
    }
    Quelqu'un pourrait m'aider ?

  2. #2
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2019
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Togo

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

    Informations forums :
    Inscription : Septembre 2019
    Messages : 22
    Par défaut
    je complète la notification : "La valeur ne peut pas être null. Nom du paramêtre : dataSet"
    merci

  3. #3
    Expert confirmé
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 470
    Par défaut
    Bonjour,
    Il ne manquerai pas un loginCredentials = new DataSet () ?

    Tatayo.

  4. #4
    Membre très actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2007
    Messages
    871
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Février 2007
    Messages : 871
    Par défaut
    Salut,

    Tu n'as pas besoin de dataset, voici ce a quoi peut ressembler ton code corrige :
    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
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
     
    using System;
    using System.Collections.Generic;
    using System.Data;
    using System.Data.SqlClient;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using System.Windows;
    using System.Windows.Controls;
    using System.Windows.Data;
    using System.Windows.Documents;
    using System.Windows.Input;
    using System.Windows.Media;
    using System.Windows.Media.Imaging;
    using System.Windows.Shapes;
     
    namespace CsMac
    {
        /// <summary>
        /// Logique d'interaction pour Window3.xaml
        /// </summary>
        public partial class Window3 : Window
        {
            public Window3()
            {
                InitializeComponent();
            }
     
            private void Enr_Click(object sender, RoutedEventArgs e)
            {
                SqlConnection sqlcon = new SqlConnection("Data Source=TGOCLC0H5YV0\\SQLSERVER;Initial Catalog=CsMac; Trusted_Connection=True;");
                try
                {
                    if (sqlcon.State == ConnectionState.Closed)
                        sqlcon.Open();
                    string req = "INSERT INTO Demandes(CodeDmd, NomDemandeur, ServiceDemandeur, DesignationCs, Qte, PU, Total, DateEtHeure, Etat, Observation) VALUES (@CodeDmd, @NomDemandeur, @ServiceDemandeur, @DesignationCs, @Qte, @PU, @Total, @DateEtHeure, @Etat, @Observation)";
                       SqlCommand cmd = new SqlCommand(req, sqlcon);
                    cmd.CommandType = CommandType.Text;
                    cmd.Parameters.Add(new SqlParameter("@CodeCmd", txtcode.Text));
                    cmd.Parameters.Add(new SqlParameter("@NomDemandeur", txtnom.Text));
                    cmd.Parameters.Add(new SqlParameter("@ServiceDemandeur", txtservice.Text));
                    cmd.Parameters.Add(new SqlParameter("@DesignationCs", txtdesignation.Text));
                    cmd.Parameters.Add(new SqlParameter("@Qte", txtqte.Text));
                    cmd.Parameters.Add(new SqlParameter("@PU", txtpu.Text));
                    cmd.Parameters.Add(new SqlParameter("@Total", txttotal.Text));
                    cmd.Parameters.Add(new SqlParameter("@DateEtHeure", txtdate.Text));
                    cmd.Parameters.Add(new SqlParameter("@Etat", txtetat.Text));
                    cmd.Parameters.Add(new SqlParameter("@Observation", txtobservation.Text));
     
                    cmd.ExecuteNonQuery();
                    MessageBox.Show("Demande enregistrée.");
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message);
                }
                finally
                {
                    sqlcon.Close();
                }
     
            }
        }
    }

  5. #5
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2019
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Togo

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

    Informations forums :
    Inscription : Septembre 2019
    Messages : 22
    Par défaut
    Merci @Tatayo et @Mermich... Quand je supprime les dataset (comme dans le code de Mermich) et que j'esssaie d'enregistrer les valeurs saisies dans le formulaire j'ai une autre erreur :"Must declare the Scalar variable "CodeDmd"". Bonjour...

  6. #6
    Expert confirmé
    Avatar de popo
    Homme Profil pro
    Analyste programmeur Delphi / C#
    Inscrit en
    Mars 2005
    Messages
    3 011
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Analyste programmeur Delphi / C#
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 3 011
    Par défaut
    C'est parce que tu as @CodeDmd dans la requête et @CodeCmd dans le paramètre

  7. #7
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2019
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Togo

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

    Informations forums :
    Inscription : Septembre 2019
    Messages : 22
    Par défaut
    ça m'a vraiment échappé... merci Popo

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

Discussions similaires

  1. Réponses: 5
    Dernier message: 25/10/2017, 18h59
  2. form2.Show() La valeur ne peut pas être null
    Par bygleader dans le forum VB.NET
    Réponses: 1
    Dernier message: 17/12/2016, 08h55
  3. Réponses: 2
    Dernier message: 11/01/2016, 09h40
  4. Réponses: 10
    Dernier message: 21/10/2013, 20h19
  5. [Débutant] La valeur ne peut pas être null. Nom du paramètre : objectType
    Par ozthewizard dans le forum VB.NET
    Réponses: 7
    Dernier message: 30/09/2011, 09h06

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