如何将IEnumerable <int>转换为Int32

Cra*_*ith 5 c# linq

我有一个linq查询将返回1个结果,这将是一个整数.我想将它分配给一个Int32变量以便稍后使用,但是我得到一个错误,它读取"int不包含RatingNumber的定义而且没有扩展方法可以找到类型为int的第一个参数的RatingNumber(你是否遗漏了) using指令或程序集引用?)

这是调用查询的代码

IEnumerable<int> newRatingNumber = getNewRecipeNumbers.newRatingNum();

        foreach (var a in newRatingNumber)
        {
            ratingNumber = a.RatingNum;
        }
Run Code Online (Sandbox Code Playgroud)

这是查询:

 public IEnumerable<int> newRatingNum()
    {
        ratingTableAdapter.Fill(recipeDataSet.Rating);
        var newRatingNum = (from a in recipeDataSet.Rating
                            where a.UserRating == 0 &&
                            a.FamilyRating == 0 &&
                            a.HealthRating == 0 &&
                            a.EaseOfCooking == 0 &&
                            a.CookingTime == 0
                            select a.RatingNum);
        return newRatingNum;
    }
Run Code Online (Sandbox Code Playgroud)

我尝试使用Convert.ToInt32将结果转换为int,这消除了编译错误,但是这创建了一个InvalidCastException.有人有主意吗?

谢谢您的帮助

克雷格

Sys*_*own 21

Linq查询的结果不是单个Int值,而是IEnumerable.因此,您需要从中获取单个值,在您的情况下,这是第一个值:

var newRatingNum = (from a in recipeDataSet.Rating
                        where a.UserRating == 0 &&
                        a.FamilyRating == 0 &&
                        a.HealthRating == 0 &&
                        a.EaseOfCooking == 0 &&
                        a.CookingTime == 0
                        select a.RatingNum).FirstOrDefault();
Run Code Online (Sandbox Code Playgroud)

FirstOrDefault() 将返回Enumberable中的第一个值,如果Enumberable为空,则返回0.