野藤 2016-03-01 09:28 采纳率: 0%
浏览 2547
已结题

Enity framework 向一个有外键的table插入数据

Enity framework 怎么向一个有外键的table插入数据。
比如一个student表:
Id(主键)
Name
ClassId(外键,Class表的主键)

一个Class表:
Id(主键,student的外键)
Name

当我用ef(版本3.5)插入一条student记录时,例如 (1,小明,一班)注:“一班”这个数据存在于class表中。
这时ef会先去class表中插入“一班”这个数据,从而出现主键不能重复的异常,student也没法插入。如果Class表中没有“一班”这个数据
那么一切会正常执行。

插入函数,我用的是ef DBcontext派生类的AddToXXX()(XXX为表名)方法
之后调用savechanges保存 就会出现class表主键冲突的问题

请问这个问题怎么解决!

代码:

                                                            student.Classes = classes;
                           student.Colleges = college;
                           student.Degrees = degree;
                           student.GraduateYears = year;
                           student.Specials = special;
                                                         ae.AddToStudents(student);
            以上class college degree year special student 全部是model(根据数据库自己生成的)并且class college degree year special的主键全部是student的外键ae是DBcontext的对象
  • 写回答

1条回答

  • threenewbee 2016-03-01 13:05
    关注

    贴出你的代码,你重复插入主键了。

    你可以用导航属性,比如
    db.ClassTable.Students.Add(new Student() { ... });
    db.SaveChanges();

    评论

报告相同问题?

悬赏问题

  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值