Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/linq/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# LINQ创建动态字段的实体_C#_Linq_Entity Framework_Linq To Entities_Entity Framework 5 - Fatal编程技术网

C# LINQ创建动态字段的实体

C# LINQ创建动态字段的实体,c#,linq,entity-framework,linq-to-entities,entity-framework-5,C#,Linq,Entity Framework,Linq To Entities,Entity Framework 5,我正在尝试使用LINQ创建一个动态字段来创建实体w/EF5。根据某些条件(我已经封装在函数中),动态字段将填充不同的值 我引用了这篇文章,但是当我运行下面的代码时,我得到了以下错误: LINQ to Entities无法识别方法“System.String FormatName()”方法,并且无法将此方法转换为存储表达式 公共静态IEnumerable SelectAllCustomers() { 使用(var db=new DatabaseContext()) { var query=db.C

我正在尝试使用LINQ创建一个动态字段来创建实体w/EF5。根据某些条件(我已经封装在函数中),动态字段将填充不同的值

我引用了这篇文章,但是当我运行下面的代码时,我得到了以下错误:

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

公共静态IEnumerable SelectAllCustomers()
{
使用(var db=new DatabaseContext())
{
var query=db.Customer.Select(c=>new
{
c、 身份证,
FullNameLastFirstMiddle=FormatName(c.First\u Name、c.Middle\u Name、c.Last\u Name),
}
);
返回query.ToList();
}
}
私有静态字符串FormatName(字符串第一,字符串中间,字符串最后)
{
//格式名
如果(!String.IsNullOrWhiteSpace(第一个))
{
如果(!String.IsNullOrWhiteSpace(中间))
返回最后一个+”、“+第一个+”+中间;
其他的
返回最后一个+“,”+第一个;
}
其他的
{
如果(!String.IsNullOrWhiteSpace(中间))
返回最后一个+“,”+中间;
其他的
最后返回;
}
}

关于如何最好地使用LINQ to Entities动态构建具有统计逻辑的字段,您有什么想法吗?

像这样的字符串格式实际上不需要转换为SQL并首先在数据库端执行。相反,只需在数据库中查询所需的信息,然后使用LINQ to对象在应用程序端执行字符串操作:

var query = db.Customer.Select(c => new
{
    c.ID,
    c.First_Name,
    c.Middle_Name,
    c.Last_Name,
})
.AsEnumerable()
.Select(c => new
{
    c.ID,
    FullNameLastFirstMiddle = 
        FormatName(c.First_Name, c.Middle_Name, c.Last_Name),
});

作为查询的一部分,您必须内联编写它,使用
?:
运算符。也许更好的办法是始终将这些字段从数据库中分离出来,并在代码中添加一个额外的属性或方法,以便在请求时执行该逻辑。@MarcinJuraszek该逻辑非常复杂,因此我正在寻找一种可以封装在方法调用中的解决方案。这有一个方法调用作为查询的一部分,但当我尝试实现此设计时,我得到了OP中提到的异常。您所指的帖子不是关于LINQ到实体的。这就不同了。我很确定你可以编写SQL,它也可以做到这一点。如果您内联条件并使用
value!=空值&&value!=“
而不是
string.IsNullOrEmpty
调用。@MarcinJuraszek他没有使用
IsNullOrEmpty
他使用的是
IsNullOrWhitespace
。不管怎样,这里的要点并不是说你不能在SQL中做到这一点,更重要的是没有令人信服的理由这样做。与某种形式的过滤不同,在DB端执行此操作不会减少通过线路发送的数据量,与排序之类的操作不同,DB无法更有效地执行此操作。当然,如果他需要在许多不同的地方进行内联操作,那么内联所有这些操作就变得更加困难。出错的几率很高。
var query = db.Customer.Select(c => new
{
    c.ID,
    c.First_Name,
    c.Middle_Name,
    c.Last_Name,
})
.AsEnumerable()
.Select(c => new
{
    c.ID,
    FullNameLastFirstMiddle = 
        FormatName(c.First_Name, c.Middle_Name, c.Last_Name),
});