当前位置:  开发笔记 > 编程语言 > 正文

C# - Linq:无法创建类型的常量值在此上下文中仅支持基本类型或枚举类型.

如何解决《C#-Linq:无法创建类型的常量值在此上下文中仅支持基本类型或枚举类型.》经验,为你挑选了1个好方法。

我正在使用此linq查询进行登录

var login = context.Person_Login
                   .Where(c => c.Username == username && c.Password == password)
                   .DefaultIfEmpty(new Person_Login({Id = -1})
                   .First();

但在执行中抛出此异常:

EntityFramework.SqlServer.dll中出现未处理的"System.NotSupportedException"类型异常

附加信息:无法创建"MyProject.MyModels.Person_Login"类型的常量值.在此上下文中仅支持基元类型或枚举类型.

Ivan Stoev.. 7

异常消息非常具有描述性.

DefaultIfEmpty(new Person_Login({Id = -1})

Linq to Entities不支持.

您可以使用以下代码

var login = context.Person_Login
    .FirstOrDefault(c => c.Username == username && c.Password == password)
    ?? new Person_Login {Id = -1};

注意,该DefaultIfEmpty方法主要用于执行LINQ左外连接.



1> Ivan Stoev..:

异常消息非常具有描述性.

DefaultIfEmpty(new Person_Login({Id = -1})

Linq to Entities不支持.

您可以使用以下代码

var login = context.Person_Login
    .FirstOrDefault(c => c.Username == username && c.Password == password)
    ?? new Person_Login {Id = -1};

注意,该DefaultIfEmpty方法主要用于执行LINQ左外连接.

推荐阅读
赛亚兔备_393
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有