- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我是 Entity Framework 的新手,正在尝试解决问题。我创建了一个不是很复杂的数据库。大约有 7 个表,其中 3 个是映射表,用于将一个表记录与另一个表记录相关联。我在这里使用的例子是这样的:
表用户
表格角色
表:用户角色
外键映射到我的数据库中。当我在 VS 2008 中创建一个新的实体模型时,图表似乎具有正确的关系,但没有为 UserRole 表创建表。该关系映射为用户和角色之间的多对多关系。
我的问题是我可以创建新用户和新角色,但我不知道如何使用现有角色创建新用户。此外,开始时 UserRole 表可能未在模型中正确映射。到目前为止,这是我的代码:
ObjectQuery<Role> roles = context.Roles;
Role role = context.Roles.Where(c => c.RoleName == "Subscriber").First();
User user = new User
{
DisplayName = "TestCreate2",
Email = "test@test.com",
Password = "test"
};
context.AttachTo("Roles", role);
user.Roles.Add(role);
context.AddToUsers(user);
context.SaveChanges();
这是我遇到的错误:
Unable to update the EntitySet 'UserRoles' because it has a DefiningQuery and no element exists in the element to support the current operation.
这是属于 UserRole 表的 xml:
<EntitySet Name="UserRoles" EntityType="RememberTheJourneyModel.Store.UserRoles" store:Type="Tables" store:Schema="dbo" store:Name="UserRoles">
<DefiningQuery>SELECT
[UserRoles].[Role_id] AS [Role_id],
[UserRoles].[User_id] AS [User_id]
FROM [dbo].[UserRoles] AS [UserRoles]</DefiningQuery>
</EntitySet>
它只是想弄清楚如何查询上下文,以便它给了我一个实际的 Role 实体。我确定问题与 UserRole 的映射方式有关,但我才刚刚开始,不知道哪里出了问题。
我确实搜索过谷歌和这个网站,但我想我还没有想出正确的搜索参数来找到可以帮助我解决这个问题的问题。我发现一个问题说 EF 对此有问题,但如果你映射表使两列都成为主键,它就会自行解决。我不知道该怎么做。这是在数据库中(使用 SQL SERVER 2005 EXPRESS)还是在映射中完成的?这是一个个人项目,因此如果需要,我可以发布有关代码或 xml 的更多详细信息。我们将不胜感激。
最佳答案
我记得以前也遇到过这个问题......我相信我通过在我的关联表中制作两个列键来修复它。
您可以在 SQL Server Management Studio 表设计器中将这两个列都设为主键。只需同时突出显示 User_Id 和 Role_Id,右键单击左侧并选择主键...这将使任何记录都不能具有相同的 User_Id 和 Role_Id 组合..使每个条目都是唯一的。
然后您可以在 Entity Framework 设计器中更新您的数据模型。希望一切顺利。
我认为,如果表没有定义任何键来确保记录是唯一的,那么 EF 将无法正确更新记录,因此框架会防范这种情况。
关于c# - 使用 Entity Framework ,我如何反射(reflect)多对多关系并将存在的实体添加到正在创建的新实体?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2125901/
一、反射 1.定义 Java的反射(reflection)机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法(即使是私有的);对于任意一个对象,都能够调用它的任意方法和属性,那么,我
有没有办法从 JavaScript 对象内部获取所有方法(私有(private)、特权或公共(public))?这是示例对象: var Test = function() { // private m
我有一个抽象类“A”,类“B”和“C”扩展了 A。我想在运行时根据某些变量创建这些实例。如下所示: public abstract class A { public abstract int
假设我们在内存中有很多对象。每个都有一个不同的ID。如何迭代内存以找到与某些 id 进行比较的特定对象?为了通过 getattr 获取并使用它? 最佳答案 您应该维护这些对象的集合,因为它们是在类属性
假设我有这个结构和一个方法: package main import ( "fmt" "reflect" ) type MyStruct struct { } func (a *MyS
C#反射简介 反射(Reflection)是C#语言中一种非常有用的机制,它可以在运行时动态获取对象的类型信息并且进行相应的操作。 反射是一种在.NET Framework中广
概述 反射(Reflection)机制是指在运行时动态地获取类的信息以及操作类的成员(字段、方法、构造函数等)的能力。通过反射,我们可以在编译时期未知具体类型的情况下,通过运行时的动态
先来看一段魔法吧 public class Test { private static void changeStrValue(String str, char[] value) {
结构体struct struct 用来自定义复杂数据结构,可以包含多个字段(属性),可以嵌套; go中的struct类型理解为类,可以定义方法,和函数定义有些许区别; struct类型是值类型
反射 1. 反射的定义 Java的反射(reflection)机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意方法和属性,既然能拿到那么,我们
反射的定义 java的反射(reflection) 机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意方法和属性,既然能拿到嘛,那么,我们就可以
我有一个 Java POJO: public class Event { private String id; private String name; private Lon
我编写了以下函数来检查给定的单例类是否实现了特征。 /** Given a singleton class, returns singleton object if cls implements T.
我正在研究 Java 反射的基础知识并观察有关类方法的信息。我需要获得一个符合 getMethod() 函数描述的规范的方法。然而,当我这样做时,我得到了一个 NoSuchMethodExceptio
我正在通过以下代码检索 IEnumerable 属性列表: BindingFlags bindingFlag = BindingFlags.Instance | BindingFlags.Public
我需要检查属性是否在其伙伴类中定义了特定属性: [MetadataType(typeof(Metadata))] public sealed partial class Address { p
我正在尝试使用 Reflections(由 org.reflections 提供)来处理一些繁重的工作,因此我不需要在很长的时间内为每个类手动创建一个实例列表。但是,Reflections 并未按照我
scala 反射 API (2.10) 是否提供更简单的方法来搜索加载的类并将列表过滤到实现定义特征的特定类? IE; trait Widget { def turn(): Int } class
我想在运行时使用反射来查找具有给定注释的所有类,但是我不知道如何在 Scala 中这样做。然后我想获取注释的值并动态实例化每个映射到关联注释值的带注释类的实例。 这是我想要做的: package pr
这超出了我的头脑,有人可以更好地向我解释吗? http://mathworld.wolfram.com/Reflection.html 我正在制作一个 2d 突破格斗游戏,所以我需要球能够在它击中墙壁
我是一名优秀的程序员,十分优秀!