【问题标题】:how to use session variable in Linq如何在 Linq 中使用会话变量
【发布时间】:2016-04-12 06:18:42
【问题描述】:

如何在 Linq Query 中获取Session["UserId"]

 var result = (from c in db.UserMaster
                      where c.UserID == Session["vUSerID"].ToString() 
                      select C ).ToList();

但是当我执行时它给了我如下错误

LINQ to Entities 无法识别方法“System.String ToString()”方法,并且该方法无法转换为存储表达式。

请指导我如何使用ToString()

【问题讨论】:

标签: c# linq


【解决方案1】:

您需要在发送它以翻译为 SQL 之前 实现该值:

var userId = Session["vUSerID"].ToString();
var result = (from c in db.UserMaster
                  where c.UserID == userId 
                  select C ).ToList();

【讨论】:

    【解决方案2】:

    或者,您可以尝试先将实体放入内存,然后应用条件来获取过滤结果,但由于潜在的性能问题不建议这样做。

    var result = db.UserMaster.Select(x => x).ToList().Where(x => x.UserId == Session["vUSerID"].ToString()).ToList();
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2017-08-29
      • 2017-04-06
      • 2013-12-19
      • 1970-01-01
      • 2023-03-02
      • 2014-07-11
      • 1970-01-01
      • 2012-02-02
      相关资源
      最近更新 更多