Returning a single value with Linq to SQL

前端 未结 4 1160
臣服心动
臣服心动 2020-12-06 05:28

I\'m learning Linq to SQL and I\'m having trouble grasping it. I\'m trying to simply return a single (boolean) value in C# with a Linq query.

I want to see if the o

相关标签:
4条回答
  • 2020-12-06 06:10
    var notify = (from s in db.AccountSettings
                  where s.UserName == username
                  select s.NotifyOnComment).Count();
    
    return  Convert.ToBoolean(notify);
    
    0 讨论(0)
  • 2020-12-06 06:15

    If you expect just one result just use Single or SingleOrDefault to get the bool. If you want the first result you can use First or FirstOrDefault.

    0 讨论(0)
  • 2020-12-06 06:18
    var notify = (from s in db.AccountSettings
                  where s.UserName == username
                  select s.NotifyOnComment).DefaultIfEmpty(false).First();
    
    //notify will either hold a bool or the AccountSettings object so
    return (!(notify == false)); // Thanks Nick. Amazing what you'll do in a hurry.
    
    0 讨论(0)
  • 2020-12-06 06:21

    Linq, by default always returns collections. If you need a single value, you can apply the .Single(), .SingleOrDefault() or .First() or .FirstOrDefault() methods.

    They differ slightly in what they do. Single() and SingleOrDefault() will only work if there is exactly or at most one record in the result. First() and FirstOrDefault() will work, even if there are more results.

    The *OrDefault() variants will return the default value for the type in case the result contained no records.

    0 讨论(0)
提交回复
热议问题