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 :

Insertion d'une clé primaire en utilisant LinqToEntities


Sujet :

ASP.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2005
    Messages
    109
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Service public

    Informations forums :
    Inscription : Décembre 2005
    Messages : 109
    Par défaut Insertion d'une clé étrangère en utilisant LinqToEntities
    Bonjour a tous,

    Je suis actuellement sur la réalisation de mon blog en Asp.Net, pour cela je travaille sur entity Framework pour mon accès a la base SQL Server. Je suis coincé sur le retour d'une valeur d'un dropdownlist (la rubrique a laquelle l'article écris appartient), je ne comprend pas ce qu'attend l'élément rubriquesReference.

    Pourriez vous m'aiguiller sur cela, merci d'avance de vos réponses.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    myBlogEntities db = new myBlogEntities(); 
    articles article = new articles(); 
    article.titre = txtTitre.Text; 
    article.texte = txtTexte.Text; 
    article.rubriquesReference.Value = Convert.ToInt32(dropDownRubrique.SelectedItem.Value); // erreur 
    article.createdOn = DateTime.Now; 
    article.updatedOn = DateTime.Now; 
     
    db.AddToarticles(article); 
    db.SaveChanges();

  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
    Essaie un truc comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    int idRubrique = Convert.ToInt32(dropDownRubrique.SelectedItem.Value);
    article.rubriques = db.Rubriques.Single(r => r.Id = idRubrique);
    (avec peut-être qq petites modifs, vu que je connais pas ton modèle...)

  3. #3
    Rédacteur
    Avatar de The_badger_man
    Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2005
    Messages
    2 745
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 745
    Par défaut
    Le seul problème avec la solution ci-dessus c'est que tu refais une requête à la base pour récupérer la rubrique.

    Théoriquement tu peux définir la rubrique de l'article via son ID en utilisant une notation un peu barbare:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    int id = Convert.ToInt32(dropDownRubrique.SelectedItem.Value);
    article.rubriquesReference.EntityKey = new EntityKey("myBlogEntities.rubriques", "rubriqueId", id);

    "myBlogEntities.rubriques" est le nom de la classe de ton context + le nom de l'entitySet correspondant aux rubriques.

    "rubriqueId" est le nom de la propriété représentant l'identifiant de la rubrique dans ton modèle.

    A corriger par rapport à ton modèle.
    Les règles du forum
    Le trio magique : FAQ + Cours + fonction rechercher
    Mes articles
    Pas de questions par messages privés svp

    Software is never finished, only abandoned.

  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 : 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 The_badger_man Voir le message
    Théoriquement tu peux définir la rubrique de l'article via son ID en utilisant une notation un peu barbare:
    A noter qu'avec EF 4, le designer peut générer une propriété pour l'ID correspondant une association, donc tu aurais une propriété RubriqueID à laquelle tu pourrais directement affecter l'ID

  5. #5
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2005
    Messages
    109
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Service public

    Informations forums :
    Inscription : Décembre 2005
    Messages : 109
    Par défaut
    vos deux exemples marchent mais ils me renvoi une erreur:

    Impossible d'insérer la valeur NULL dans la colonne 'rubriques_id', table 'myBlog.dbo.articles'. Cette colonne n'accepte pas les valeurs NULL. Échec de INSERT.
    L'instruction a été arrêtée.
    Pour l'instant j'en suis la, au niveau de mon int "idRubrique" elle n'est pourtant pas nulle :s

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    int idRubrique = Convert.ToInt16(dropDownRubrique.SelectedValue);
    myBlogEntities db = new myBlogEntities();
    articles article = new articles();
    article.rubriques = db.rubriques.First(r => r.id_rubriques == idRubrique);
    article.titre = txtTitre.Text;
    article.texte = txtTexte.Text;
    article.createdOn = DateTime.Now;
    article.updatedOn = DateTime.Now;
     
    db.AddToarticles(article);
    db.SaveChanges();

  6. #6
    Membre éprouvé
    Inscrit en
    Septembre 2007
    Messages
    1 137
    Détails du profil
    Informations personnelles :
    Âge : 42

    Informations forums :
    Inscription : Septembre 2007
    Messages : 1 137
    Par défaut
    Le message me semble tres clair, tu essayes de mettre null dans une colonne qui n'accepte pas les null

Discussions similaires

  1. Insertion d'une clé primaire dans une autre table
    Par kensem dans le forum PL/SQL
    Réponses: 1
    Dernier message: 26/05/2011, 23h33
  2. Création d'une clé primaire en utilisant un trigger
    Par king_abdel dans le forum PL/SQL
    Réponses: 6
    Dernier message: 04/08/2010, 09h42
  3. Probleme d'insertion d'une clef primaire OleAdo
    Par blondelle dans le forum C++Builder
    Réponses: 1
    Dernier message: 26/03/2007, 12h23
  4. Réponses: 5
    Dernier message: 29/09/2005, 09h35
  5. insertion d'une clé primaire avec un "d" apostroph
    Par imer5 dans le forum PostgreSQL
    Réponses: 5
    Dernier message: 18/05/2005, 14h51

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