0

我有一个TPM_TASKS包含所有任务的表,以及一个TPM_USER包含所有用户的表。然后我有一个名为的表TPM_USERTASKS,其中包含一个UserIdTaskId存储一个任务分配给一个用户。

我正在尝试选择分配给给定TPM_USER实体的所有任务。到目前为止,我已经尝试过:

TPM_USER user = UserManager.GetUser(context, UserId); //Lookup the user in the DB
var tasks = (from t in context.TPM_TASK.Include("TPM_USER")
             where t.TPM_USER.Contains<TPM_USER>(user)
             select t);

但是,当我尝试迭代时,我得到了运行时异常:

无法创建“Entity.TPM_USER”类型的常量值。此上下文仅支持原始类型(“例如 Int32、String 和 Guid”)。

我相信它不喜欢我将 TPM_USER 对象传递到Contains(). 这可能是有道理的,因为它必须生成一个嵌套的 SELECT 语句而不是一个IN子句,这可能是 EF 无法做到的。但是,肯定有办法进行这样的查询,对吧?

注意:如果你很聪明,你可能会问我为什么我不只是查询TPM_USERTASKS然后加入匹配TPM_TASK。嗯,我很想这样做。但是,我整个上午都在尝试让 EF 生成 TPM_USERTASK 模型,但它根本不会。该表显示在模型存储中,我可以针对它定义关系。它没有出现在我可以从数据库中添加或刷新的实体列表中,我什至尝试删除整个 .EDMX 文件并重新创建它。我猜在多对多关系中使用的东西也不能是一个独立的实体?

4

2 回答 2

2

您的查询将如下所示:

var tasks = (from t in context.TPM_TASK.Include("TPM_USER")
            where t.TPM_USER.Any(x => x.Id == user.Id)
            select t);

但无论如何,这有点偏离了。TPM_USER 对象应该已经具有对 TPM_TASK 的引用。所以 user.TPM_TASKS 应该给你给定用户的所有任务,否则你的模型在某种程度上是错误的。

任务多对多用户意味着:一个任务,许多用户。一个用户,多个任务。

还是我错了?

更新

如果你真的想在你的模型中获得 TPM_USERTASKS 类,你必须向它添加一个单独的 Key/Id。

create table TPM_USERTASKS (
    ID      int identity(1,1)   not null
    UserId  int                 not null,
    TaskId  int                 not null,
    constraint [PK_TPM_USERTAKS] primary key (ID)
)
于 2012-06-18T18:32:32.067 回答
2

好吧,您必须使用 Navigation 属性。

在多对多关系中,这意味着您必须有一个

public virtual ICollection<TPM_USER> TpmUsers {get;set;}

在您的 TPM_TASK 课程中

和/或

public virtual ICollection<TPM_TASK> TpmTasks{get;set;}

在你的 TMP_USER 类中。

如果不这样做,您将无法编写连接这两个实体的查询。

这样,您可以将查询编写为

var userTasks = context.TPM_TASK
                   .Where(task => task.TpmUsers
                         .Any(user => user.Id == UserId));
于 2012-06-18T18:34:03.017 回答