首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >实体框架- Oracle 11 -在两个表之间插入关联/链接记录

实体框架- Oracle 11 -在两个表之间插入关联/链接记录
EN

Stack Overflow用户
提问于 2015-07-17 13:13:58
回答 1查看 113关注 0票数 2

我正在尝试在已经存在的两个项目之间创建一个新的链接。

链接表有:

代码语言:javascript
复制
{
   userid - with a fk to the user table;
   roleid - with a fk to the role table;
}

我所链接的记录已经存在于角色和用户表中。

代码语言:javascript
复制
using (Entities db = new Entities())
{
   ORA_ASPNET_USERS usersTable = db.ORA_ASPNET_USERS
       .Where(u => u.USERID == UserId).First();
   usersTable.ORA_ASPNET_ROLES
       .Add(db.ORA_ASPNET_ROLES.Where(c => c.ROLEID == RoleId).First());

   db.ORA_ASPNET_USERS.Add(usersTable);
   db.SaveChanges();
}

我遇到的问题是,它试图在User表中插入一个新记录,并且应该只在链接表中插入一个记录。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-07-17 13:34:37

当您使用Add方法时,再次添加用户,它将该实体的状态更改为Added。如果没有禁用跟踪更改或延迟loading.By默认设置,则不需要这样做,实体框架将自动执行检测更改。请再次尝试删除该行:

代码语言:javascript
复制
using (Entities db = new Entities())
{
   ORA_ASPNET_USERS usersTable = db.ORA_ASPNET_USERS.First(u => u.USERID == UserId);
   usersTable.ORA_ASPNET_ROLES
       .Add(db.ORA_ASPNET_ROLES.First(c => c.ROLEID == RoleId));

   db.SaveChanges();
}

另一件事是您不需要调用Where方法,您可以将相同的条件传递给First方法。唯一的问题是,如果用户或角色不存在,EF将抛出一个异常,最好调用FirstOrDefault方法并检查返回的实体是否为null。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31476683

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档