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

ASP.NET Discussion :

Migration Framework => erreur lors d'une insertion en base


Sujet :

ASP.NET

  1. #1
    Membre habitué
    Avatar de Spidermeu
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Février 2006
    Messages
    147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Février 2006
    Messages : 147
    Points : 151
    Points
    151
    Par défaut Migration Framework => erreur lors d'une insertion en base
    Bonjour,
    je suis actuellement en train de migrer un site web développé en framework 1.1 vers du 2.0.
    La migration est pratiquement fini. Malheureusement, une erreur me résiste et je ne trouve pas l'erreur très parlante.
    En fait, il s'agit d'une page qui permet d'insérer en base (SQL server) des données. cela fonctionnait bien avec IIS configuré en 1.1, mais en 2.0, j'ai l'erreur suivante :
    No mapping exists from object type System.RuntimeType to a known managed provider native type
    Le code C# d'insertion comporte 1800 lignes de code, et ce n'est que de l'insertion de données.

    Sur internet, j'ai touvé quelques liens intérressants comme celui-ci :
    Où il est recommandé de remplacer typeof par SqldbType.Type
    Et enfin, celui-ci

    Pourtant, dans le code, à chaque fois il y a bien SqldbType.Type et il n'y a pas de procédure stocké....

    Des avis ??

    Merci d'avance

  2. #2
    Membre habitué
    Avatar de Spidermeu
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Février 2006
    Messages
    147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Février 2006
    Messages : 147
    Points : 151
    Points
    151
    Par défaut
    J'ai réussi à avancer avec le debugger.

    le bout de code qui ne fonctionne pas est le suivant :

    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
    public int SaveToBdd(string CS)
    		{
    			int resultat = -1;
    			SqlConnection conn = new SqlConnection(CS);
    			try
    			{
    				conn.Open();
    				if (this.Id == -1)
    				{// si nouveau
    SqlCommand cmd = new SqlCommand("Insert into BIAdresse (BIADDRNom,BIADDRAdresse,BIADDRCp,BIADDRVille) values (@BIADDRNom,@BIADDRAdresse,@BIADDRCp,@BIADDRVille) SET @BIADDRId = @@Identity",conn);
                        cmd.Parameters.Add("@BIADDRNom", typeof(string));
                        cmd.Parameters.Add("@BIADDRAdresse", typeof(string));
                        cmd.Parameters.Add("@BIADDRCp", typeof(string));
                        cmd.Parameters.Add("@BIADDRVille", typeof(string));
                        cmd.Parameters.Add("@BIADDRId", typeof(int));
                        cmd.Parameters["@BIADDRId"].Direction = ParameterDirection.Output;
     
                        cmd.Parameters["@BIADDRNom"].Value = this.Nom;
                        cmd.Parameters["@BIADDRAdresse"].Value = this.Adresse;
                        cmd.Parameters["@BIADDRCp"].Value = this.Cp;
                        cmd.Parameters["@BIADDRVille"].Value = this.Ville;
     
    					cmd.ExecuteNonQuery();
    					this.Id = (int)cmd.Parameters["@BIADDRId"].Value;
    					resultat = Id;
     
    				}
    				else
    				{
    					//UPDATE				}
     
    			}
    			catch (Exception exp)
    			{
    				throw exp;
    			}
    			finally
    			{
    				conn.Close();
    			}
    l'erreur se produit au moment de l'exécution de la requête :
    Même en applliquant les règles décrite dans les liens de mon premier post, j'ai toujours la même erreur.

  3. #3
    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 : 42
    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
    Points : 39 749
    Points
    39 749
    Par défaut
    typeof renvoie un objet Type, or aucune surcharge de SqlParameterCollection.Add ne prend en paramètre un Type... Il faut effectivement utiliser un SqlDbType à la place :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    ...
    SqlCommand cmd = new SqlCommand("Insert into BIAdresse (BIADDRNom,BIADDRAdresse,BIADDRCp,BIADDRVille) values (@BIADDRNom,@BIADDRAdresse,@BIADDRCp,@BIADDRVille) SET @BIADDRId = @@Identity",conn);
                        cmd.Parameters.Add("@BIADDRNom", SqlDbType.NVarChar);
                        cmd.Parameters.Add("@BIADDRAdresse", SqlDbType.NVarChar);
                        cmd.Parameters.Add("@BIADDRCp", SqlDbType.NVarChar);
                        cmd.Parameters.Add("@BIADDRVille", SqlDbType.NVarChar);
                        cmd.Parameters.Add("@BIADDRId", SqlDbType.Int);
                        cmd.Parameters["@BIADDRId"].Direction = ParameterDirection.Output;
     
                        cmd.Parameters["@BIADDRNom"].Value = this.Nom;
                        cmd.Parameters["@BIADDRAdresse"].Value = this.Adresse;
                        cmd.Parameters["@BIADDRCp"].Value = this.Cp;
                        cmd.Parameters["@BIADDRVille"].Value = this.Ville;
    ...

  4. #4
    Membre habitué
    Avatar de Spidermeu
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Février 2006
    Messages
    147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Février 2006
    Messages : 147
    Points : 151
    Points
    151
    Par défaut
    c'est bon, ca fonctionne.
    Merci de ton aide. En fait, j'avais bien fais la modif dans la méthode mais sa bloquait aussi plus loin car il y avait bien une 100aine de ligne à modifier.
    En tout cas, ta confirmation m'a permis de résoudre le soucis.
    Merci encore.

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

Discussions similaires

  1. Erreur lors d'une insertion dans base de données
    Par MeryemDahan dans le forum JDBC
    Réponses: 2
    Dernier message: 14/05/2014, 09h39
  2. Récupération message d'erreur lors d'une insertion dans une BDD
    Par LoDev dans le forum VB 6 et antérieur
    Réponses: 11
    Dernier message: 22/12/2007, 19h11
  3. erreur lors d''une insertion
    Par lilemy dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 18/06/2007, 09h54
  4. erreur lors d'une insertion
    Par poula dans le forum Oracle
    Réponses: 1
    Dernier message: 24/12/2006, 18h07
  5. Erreur lors d'une insertion
    Par chleuh dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 22/11/2006, 07h36

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