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

问题描述

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的对象

解决方案

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

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

时间: 2024-12-23 12:30:52

entity framework-Enity framework 向一个有外键的table插入数据的相关文章

跪求大虾。 解决小问题。 关于一个主外键修改问题。。

问题描述 我想修改主表中的一个字段.也就是外键.我实现的SQL语句是这样的updateCardsetCardTypeId=@CardTypeId,CardNo=@cardNo,CardPassword=@CardPassword,CardDesc=@CardDesc,CardState=@CardStatewhereCardId=@cardIdi=DBHelper.ExecuteCommand(sql,newSqlParameter("@CardTypeId",card.CardTyp

实现删除主表数据时, 判断与之关联的外键表是否有数据

问题描述:某个基础信息表,与系统中30多个表存在外键关系,当删除基础数据时,需要判断是否已经被用过,如果用过则更改标志位,如果没有用过则直接删除,如何能很好实现这个处理?最好能够自动适应表的变化 问题解决(SQL Server 2005)-- SQL Server 2005的错误处理容易控制, 因此, SQL Server 2005中可以直接删除, 通过错误处理来确定是否需要更新. -- 示例如下.USE tempdbGO CREATE TABLE m(    id int PRIMARY KE

cvs 数据库 主键外键-CVS格式文件数据导入新数据库后自动生成主键外键

问题描述 CVS格式文件数据导入新数据库后自动生成主键外键 以前将数据库中的数据导出来了,后来手贱把给数据库毁了. 现在希望通过以前导出来的CVS文件数据恢复以前的数据库,最好是自动的,主键外键自动关联自动生成[里边表实在太多了]. 什么数据库都行,什么MySQL.SQLServer都可以,只求能重建以前的数据库啊! 不知道各位大神有没有可行的办法啊? 解决方案 没办法,只有数据.需要添加SQL语句

oracle中使用on delete cascade和on delete set null来建立外键

oracle中使用on delete cascade和on delete set null来建立外键 其面我们介绍了创建外键约束时如果使用oracle默认的创建方式,在删除被参照的数据时,将无法被删除,这一点在oracle9i中给了我们更多灵活的选择,我们可是使用on delete cascade和 on delete set null关键字来决定删除被参照数据时是否要将参照这个数据的那些数据一并删除,还是将那些参照这条数据的数据的对应值赋空. 例如下面这两个表中分别存的时员工的基本信息和公司的

mysql外键约束使用详解

MySQL有两种常用的引擎类型:MyISAM和InnoDB.目前只有InnoDB引擎类型支持外键约束.InnoDB中外键约束定义的语法如下: [CONSTRAINT [symbol]] FOREIGN KEY     [index_name] (index_col_name, ...)     REFERENCES tbl_name (index_col_name,...)     [ON DELETE reference_option]     [ON UPDATE reference_opt

MySQL · 答疑解惑 · 外键删除bug分析

背景 你是否曾为Error on rename of './test/#sql-78fd_780371' to './test/t2' (errno: 150)这样的错误而不解,如stackoverflow上的这个问题? 下面我们来复现下: drop table t2; drop table t1; create table t1(c1 int primary key, c2 int); create table t2(c1 int primary key, c2 int , constrain

Hibernate外键许为NULL,JSP如何取值。

问题描述 前提:  1,Hibernate设置:      一个主表A,其中有一个字段外键关联一个基础信息表B,容许为NULL.延迟加载.  2,DAO      直接查询主表A,返回主表A的值对象.  3,系统使用框架:      SSH问题:  在JSP中,直接使用:${主表A.信息表B.外键字段的名称} 时,出错.请问如何解决. 解决方案 恩,在<%@page%>里面加isELIgnored='false'.先让jstl能用.而jstl遇到错误只是不显示而已,不会报错的.这就可以符合你的

关于MySQL外键的简单学习教程_Mysql

在MySQL中,InnoDB引擎类型的表支持了外键约束. 外键的使用条件: 1.两个表必须是InnoDB表,MyISAM表暂时不支持外键(据说以后的版本有可能支持,但至少目前不支持): 2.外键列必须建立了索引,MySQL 4.1.2以后的版本在建立外键时会自动创建索引,但如果在较早的版本则需要显示建立: 3.外键关系的两个表的列必须是数据类型相似,也就是可以相互转换类型的列,比如int和tinyint可以,而int和char则不可以: 外键的好处:可以使得两张表关联,保证数据的一致性和实现一些

MySQL外键使用及说明详解_Mysql

一.外键约束 MySQL通过外键约束来保证表与表之间的数据的完整性和准确性. 外键的使用条件: 1.两个表必须是InnoDB表,MyISAM表暂时不支持外键(据说以后的版本有可能支持,但至少目前不支持): 2.外键列必须建立了索引,MySQL 4.1.2以后的版本在建立外键时会自动创建索引,但如果在较早的版本则需要显示建立: 3.外键关系的两个表的列必须是数据类型相似,也就是可以相互转换类型的列,比如int和tinyint可以,而int和char则不可以: 外键的好处: 可以使得两张表关联,保证