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 :

Problème d'insert c#


Sujet :

C#

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2011
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2011
    Messages : 14
    Par défaut Problème d'insert c#
    Bonjour
    J'ai un problème dans un insert. Aucun message d'erreur ne s'affiche sur l'écran, pourtant aucun insert se fait dans ma base...
    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
    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
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
     
     public string GetConnectionString()
        {
     
     
            return System.Configuration.ConfigurationManager.ConnectionStrings["csVinotheque"].ConnectionString;
     
        }
     
        private void ExecuteInsert( string nom, string adresse, string ville, string codepostal, string pays, string telephone, string email, string pseudo, string password)
        {
     
            SqlConnection conn = new SqlConnection(GetConnectionString());
     
     
     
            string sql = "INSERT INTO clients ( nom , adresse, ville, codepostal, pays, telephone, email, pseudo, password) VALUES "
     
                        + " (@nom,@adresse,@ville,@codepostal,@pays,@telephone,@email,@pseudo,@password)";
     
            try
            {
     
                conn.Open();
     
     
                SqlCommand cmd = new SqlCommand(sql, conn);
     
                SqlParameter[] param = new SqlParameter[9];
     
     
     
                //param[0] = new SqlParameter("@id", SqlDbType.Int, 20);
     
     
     
                param[0] = new SqlParameter("@nom", SqlDbType.NChar, 20);
                param[1] = new SqlParameter("@adresse", SqlDbType.NChar, 120);
                param[2] = new SqlParameter("@ville", SqlDbType.NChar, 64);
                param[3] = new SqlParameter("@codepostal", SqlDbType.NChar, 32);
                param[4] = new SqlParameter("@pays", SqlDbType.NChar, 32);
                param[5] = new SqlParameter("@telephone", SqlDbType.NChar, 32);
                param[6] = new SqlParameter("@email", SqlDbType.NChar, 64);
                param[7] = new SqlParameter("@pseudo", SqlDbType.VarChar, 50);
                param[8] = new SqlParameter("@password", SqlDbType.VarChar, 50);
     
     
     
                param[0].Value = nom;
     
                param[1].Value = adresse;
     
                param[2].Value = ville;
     
                param[3].Value = codepostal;
     
                param[4].Value = pays;
     
                param[5].Value = telephone;
     
                param[6].Value = email;
     
                param[7].Value = pseudo;
     
                param[8].Value = password;
     
     
     
                for (int i = 0; i < param.Length; i++)
                {
     
                    cmd.Parameters.Add(param[i]);
     
                }
     
                cmd.CommandType = CommandType.Text;
     
                cmd.ExecuteNonQuery();
     
            }
     
            catch (System.Data.SqlClient.SqlException ex)
            {
     
                string msg = "Insert Error:";
     
                msg += ex.Message;
     
     
     
            }
     
            finally
            {
     
                conn.Close();
     
            }
     
        }
     
        protected void Button1_Click(object sender, EventArgs e)
        {
     
     
            if ((pse.Text != "") && (pas.Text != "") && (nom.Text != "") && (adr.Text != "") && (vil.Text != "") && (cp.Text != "") && (pay.Text != "") && (tel.Text != "") && (mail.Text != ""))
            {
                ExecuteInsert(nom.Text, adr.Text, vil.Text, cp.Text, pay.Text, tel.Text, mail.Text, pse.Text, pas.Text);
                Response.Redirect("Identification.aspx");
            }
            else
            {
                Label2.Visible = true;
            }
        }
    Merci

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Par défaut
    Citation Envoyé par DenisBuzz Voir le message
    Aucun message d'erreur ne s'affiche sur l'écran
    C'est normal, dans ton catch tu crées un message d'erreur mais tu ne fais rien pour l'afficher...

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2011
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2011
    Messages : 14
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    throw new Exception(msg);
    J'ai rajouté ça à mon catch, et j'obtient l'erreur suivante:

    System.Exception: Insert Error:Impossible d'insérer la valeur NULL dans la colonne 'idclient', table 'C:\USERS\PANCRATE\VINOTHEQUE\APP_DATA\VINOTHEQUE.MDF.dbo.clients'. Cette colonne n'accepte pas les valeurs NULL. Échec de INSERT.
    L'instruction a été arrêtée.
    Comment puis je faire pour que ma valeur s'incrémente automatiquement.

    Je travail avec visual studio 2010.

  4. #4
    Membre émérite

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Juin 2011
    Messages
    487
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Finance

    Informations forums :
    Inscription : Juin 2011
    Messages : 487
    Par défaut
    Rien à voir avec Visual Studio 2010, c'est ta base de données qui pose soucis, ou plutôt la manière dont tu as crée ta table.

    Il faut que tu spécifies que c'est à ta DB de gérer l'ID et de l'autoincrémenter, etc ...
    Mon blog sur les technos .NET et Agile -> http://blog.developpez.com/maximepalmisano/

  5. #5
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2011
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2011
    Messages : 14
    Par défaut
    Je me doute que l'erreur vient de là .
    Mais comment puis-je dire qu'il faut auto-incrémenter cette colonne lors d'un insert?

  6. #6
    Membre émérite

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Juin 2011
    Messages
    487
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Finance

    Informations forums :
    Inscription : Juin 2011
    Messages : 487
    Par défaut
    Tu ne nous as pas dit la db soit dit en passant ...

    Pour savoir comment ajouter l'auto incrémentation, en général c'est direction Google, MSDN & F1 mais j'suis dans un bon jour donc je vais te donner un indice :

    http://msdn.microsoft.com/en-us/libr...v=sql.80).aspx

    Enjoy !
    Mon blog sur les technos .NET et Agile -> http://blog.developpez.com/maximepalmisano/

  7. #7
    Membre émérite Avatar de kheironn
    Homme Profil pro
    Chef de projets technique C# / MVC / .Net
    Inscrit en
    Février 2007
    Messages
    822
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Chef de projets technique C# / MVC / .Net
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2007
    Messages : 822
    Par défaut
    Citation Envoyé par DenisBuzz Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    throw new Exception(msg);
    Nooooooooooooonnn, , tu rejettes un nouvelle exception et tu perds la trace des exceptions d'avant ! Fais des logs dans un fichier (vu que c'est un pbm de db) ou pour tester un affichage, ou une sortie de message (dans ton cas, ça me parait pas mal), ou autre.
    Ceci-dit, on fait plutôt un try/finnaly dans une DAL et on laisse l'exception remonter aux couches appelantes.


    Citation Envoyé par DenisBuzz Voir le message
    Je me doute que l'erreur vient de là .
    Mais comment puis-je dire qu'il faut auto-incrémenter cette colonne lors d'un insert?
    Dans la création de ta table, tu as un endroit où le définir, ou en SQL comme l'a dit Maxime...

Discussions similaires

  1. problème d'insertion de données
    Par Falgan dans le forum ASP
    Réponses: 2
    Dernier message: 06/04/2004, 09h29
  2. Probléme d'insertion par défault
    Par xavier62 dans le forum SQL
    Réponses: 7
    Dernier message: 28/11/2003, 13h03
  3. [Interbase 7] Problème d'insertion de données
    Par Tuscelan dans le forum InterBase
    Réponses: 12
    Dernier message: 19/11/2003, 22h58
  4. STL : std::set problème avec insert ...
    Par Big K. dans le forum MFC
    Réponses: 13
    Dernier message: 08/11/2003, 01h02
  5. Problème d'insertion avec MySQL
    Par Sonny dans le forum ASP
    Réponses: 13
    Dernier message: 28/08/2003, 13h52

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