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

Framework .NET Discussion :

[Entity] Problème de "SaveChanges()"


Sujet :

Framework .NET

  1. #1
    Membre à l'essai
    Inscrit en
    Octobre 2006
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 22
    Points : 13
    Points
    13
    Par défaut [Entity] Problème de "SaveChanges()"
    Bonjour à tous,

    Je sais plus quoi faire ...

    Je mets en pièce jointe un petit projet qui contient :
    - une base SQL Server Compact avec un table "Project".
    - une application WPF avec une fenêtre contenant une datagrid et un bouton.

    J'aimerais pouvoir ajouter des lignes à la grille (ce qui semble se faire) et sauver les nouvelles lignes en base au click sur le bouton "Save".

    Ca ne plante pas mais rien n'est sauvegarder ...

    Quelqu'un aurait la solution ?

    Merci d'avance !!!

    Fabrice
    Fichiers attachés Fichiers attachés

  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 : 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

  3. #3
    Membre à l'essai
    Inscrit en
    Octobre 2006
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 22
    Points : 13
    Points
    13
    Par défaut
    Merci pour ta réponse mais non le problème ne vient pas de là.

    Après quelques tests supplémentaires, je constate que c'est le résultat de ma query qui semble être détaché du context.

    Si j'affecte directement mon entité à mon DataContext, ça marche ...

    Je continue mes recherches ...

  4. #4
    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
    OK

    Mais poste plutôt les bouts de code liés à ton problème, parce qu'à mon avis pas grand monde aura le courage de télécharger ton zip, de l'extraire, d'ouvrir la solution, de parcourir tout le projet, etc...

  5. #5
    Membre éprouvé Avatar de anthyme
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    1 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 559
    Points : 1 257
    Points
    1 257
    Par défaut
    oui Flemme + 1

  6. #6
    Membre chevronné
    Profil pro
    Inscrit en
    Février 2005
    Messages
    1 273
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 1 273
    Points : 2 202
    Points
    2 202
    Par défaut
    Citation Envoyé par faabriice Voir le message
    Merci pour ta réponse mais non le problème ne vient pas de là.

    Après quelques tests supplémentaires, je constate que c'est le résultat de ma query qui semble être détaché du context.

    Si j'affecte directement mon entité à mon DataContext, ça marche ...

    Je continue mes recherches ...
    Bah oui c'est assez évident.

    Déjà tu fait une requête linq, et tu update la collection...

    Si tu regarde ton object context, il est vide --> Les collections ne sont jamais attachées.

    Il faut que attaches les objets dans le context.

    Le tuto qu'il te faut est :là.

  7. #7
    Candidat au Club
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 3
    Points : 3
    Points
    3
    Par défaut
    Bonjour,

    Pour ma part, le problème persiste.
    Lors que je veux sauvegarder une modification sur une ligne de ma table avec SaveChanges(), l'instruction ne plante pas mais je n'ai pas de modification en base de données.

    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
               string sTrace = string.Empty;
                Int64 iLigne = 0;
                idEntrepriseEntities1 ctx = new idEntrepriseEntities1(new Uri("http://localhost:1366/DataServiceIdEntreprise.svc"));
    
                try
                {
                    iLigne = Int32.Parse(tbNumeroLigneModif.Text);
                    TLigne l_oLigneModif = (from c in ctx.TLigne
                                        where c.LigId == iLigne
                                        select c).First();
                    
                    l_oLigneModif.LigLibelle = tbLibelleLigneModif.Text;
                    ctx.UpdateObject(l_oLigneModif);
                    ctx.SaveChanges();           
                }
                catch (DataServiceRequestException exc)
                {
                    lbTraceModif.Text = exc.Message;
                }
    Encore pire lors d'une demande d'ajout de ligne dans ma table :

    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
                string sTrace = string.Empty;
                Int64 iLigne = 0;
                bool bResult = false;
                idEntrepriseEntities1 ctx = new idEntrepriseEntities1(new Uri("http://localhost:1366/DataServiceIdEntreprise.svc"));
    
                try
                {
                    TLigne l_oLigneAjout = new TLigne();
                    //l_oLigneAjout.LigId = Int32.Parse(tbNumeroLigneAjout.Text);
                    l_oLigneAjout.LigLibelle = tbLibelleLigneAjout.Text;
    
                    ctx.AddToTLigne (l_oLigneAjout);
                    ctx.SaveChanges();
                }
                catch (DataServiceRequestException exc)
                {
                    lbTraceAjout.Text = exc.Message;
                }
    EXCEPTION :
    Une erreur s'est produite lors du traitement de cette requête.
    Voici la config de mon service :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
                config.SetEntitySetAccessRule("*", EntitySetRights.All);
                config.SetServiceOperationAccessRule("*", ServiceOperationRights.All);

    Merci d'avance pour votre aide

Discussions similaires

  1. [Wamp] Problème d'insertion avec quote d'un formulaire
    Par cyberdevelopment dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 1
    Dernier message: 20/08/2006, 18h55
  2. [SQL-Server] Problèmes de guillemets et quotes dans un INSERT
    Par gregb34 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 05/05/2006, 09h40

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