gpt4 book ai didi

c# - 在 Linq to entities 中将 int 转换为字符串的问题

转载 作者:IT王子 更新时间:2023-10-29 03:29:44 27 4
gpt4 key购买 nike

var items = from c in contacts
select new ListItem
{
Value = c.ContactId, //Cannot implicitly convert type 'int' (ContactId) to 'string' (Value).
Text = c.Name
};
var items = from c in contacts
select new ListItem
{
Value = c.ContactId.ToString(), //Throws exception: ToString is not supported in linq to entities.
Text = c.Name
};

无论如何我可以做到这一点吗?请注意,在 VB.NET 中使用第一个片段没有问题,它工作得很好,VB 很灵活,我无法适应 C# 的严格!!!

最佳答案

对于 EF v4,您可以使用 SqlFunctions.StringConvert . int 没有重载,因此您需要转换为 double 或 decimal。您的代码最终看起来像这样:

var items = from c in contacts
select new ListItem
{
Value = SqlFunctions.StringConvert((double)c.ContactId).Trim(),
Text = c.Name
};

关于c# - 在 Linq to entities 中将 int 转换为字符串的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1066760/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com