无法将“int”转换为“System.Predicate”。

6

我遇到了这个错误:无法将“int”转换为“System.Predicate ServerHomeWork.Models.Organisation”

在 OrgList.Add(Organisation.Find(UTO.OrganisationId); 这行代码中,属性 UTO.OrganisationId 是 int 类型,但仍然提示出错。有人能告诉我这里出了什么问题吗?

以下是代码:

public virtual List<Organisation> Organisation
{
    get
    {
        List<UsersToOrganisations> UserToOrg = UsersToOrganisations.FindListOfOrganisations(UserId);
        List<Organisation> OrgList = new List<Models.Organisation>();

        if (UserToOrg.Count > 0)
            foreach (UsersToOrganisations UTO in UserToOrg)
                OrgList.Add(Organisation.Find(UTO.OrganisationId));
        else
            OrgList.Add(new Organisation("No organisation was found.", 0));


        return OrgList;
    }
} 

这是UserToOrganisation类

class UsersToOrganisations
{
    public int Id { get; set; }
    public int UserId { get; set; }
    public int OrganisationId { get; set; }
    public bool MainOrganisation { get; set; }

    /// <summary>
    /// Constructor for entity framework
    /// </summary>
    public UsersToOrganisations() { }

    /// <summary>
    /// Constructor for creation
    /// </summary>
    /// <param name="UserId"></param>
    /// <param name="OrganisationId"></param>
    public UsersToOrganisations(int UserId, int OrganisationId, bool MainOrganisation)
    {
        this.UserId = UserId;
        this.OrganisationId = OrganisationId;
        this.MainOrganisation = MainOrganisation;
    }

    public class UsersToOrganisationsContext : DbContext
    {
        public DbSet<UsersToOrganisations> UserToOrganisation { get; set; }
    }

    /// <summary>
    /// Get the list of organisations of a single user
    /// </summary>
    /// <param name="UserId"></param>
    /// <returns></returns>
    public static List<UsersToOrganisations> FindListOfOrganisations(int UserId)
    {
        using (var context = new UsersToOrganisationsContext())
        {
            var organisation = (from uto in context.UserToOrganisation
                               where uto.UserId == UserId
                                select uto);
            return organisation.ToList();
        }
    }

    /// <summary>
    /// Get the main organisation of a user
    /// </summary>
    /// <param name="UserId"></param>
    /// <returns></returns>
    public static UsersToOrganisations FindMainOrganisation(int UserId)
    {
        using (var context = new UsersToOrganisationsContext())
        {
            var UserToOrganisation = context.UserToOrganisation
                  .Where(uto => uto.UserId == UserId && uto.MainOrganisation == true)
                  .SingleOrDefault();

            return UserToOrganisation; 
        }
    }

}

你不是漏了一个闭合的 ) 吗? - Idos
是的,抱歉我这样做了。但是Visual Studio给出的消息仍然是相同的。 - StuiterSlurf
3个回答

8
Find 接受一个谓词作为参数,而您提供的仅是一个整数。
请尝试以下操作:
OrgList.Add(Organisation.Find(u => u.OrganisationId == UTO.OrganisationId));

5
我发现这个问题是因为我使用了List.Find()而不是List.Contains()。改用List.Contains()将只需要一个int,所以不需要谓词。

1
问题在于您的lambda表达式中的 OrgList.Add(Organisation.Find(UTO.OrganisationId));

您想做类似这样的事情 OrgList.Add(Organisation.Find(item => item.OrganisationId == UTO.OrganisationId));

有关更多信息:MSDN上的List(T).Find


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接