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#的严格!!


当前回答

你可以试试:

var items = from c in contacts
        select new ListItem
        {
            Value = Convert.ToString(c.ContactId), 
            Text = c.Name
        };

其他回答

如果你使用实体框架,你想让唯一的int可接受,那么你可以在linq查询中使用这个,你可以尝试这个

var items = from c in contacts
        select new ListItem
        {
            Value = (int)ContractId 
            Text = c.Name
        };

它会工作,因为使用(int)会将你的值转换为int,所以你不需要将字符串转换为int,你会得到你想要的结果。

这在我的项目中很有用,我想对你也会有帮助

Brian Cauthon的回答非常棒!只是一个小更新,对于EF 6,类被移动到另一个名称空间。所以,在EF 6之前,你应该包括:

System.Data.Objects.SqlClient

如果您更新到EF 6,或者只是使用这个版本,请包括:

System.Data.Entity.SqlServer

通过使用EF6包含不正确的名称空间,代码将正常编译,但将抛出运行时错误。我希望这篇笔记有助于避免一些混乱。

还有一个解决方案:

c.ContactId + ""

只需添加空字符串,它将被转换为字符串。

你可以试试:

var items = from c in contacts
        select new ListItem
        {
            Value = Convert.ToString(c.ContactId), 
            Text = c.Name
        };

使用MySql, SqlFunctions。StringConvert不适合我。因为我在我的项目中使用SelectListItem在20多个地方,我想要一个解决方案,工作不扭曲20+ LINQ语句。我的解决方案是子类SelectedListItem,以提供一个整数setter,这将类型转换从LINQ。显然,这种解决方案很难概括,但对我的特定项目非常有帮助。

要使用,创建以下类型并在您的LINQ查询中使用SelectedListItem,并使用IntValue代替Value。

public class BtoSelectedListItem : SelectListItem
{
    public int IntValue
    {
        get { return string.IsNullOrEmpty(Value) ? 0 : int.Parse(Value); }
        set { Value = value.ToString(); }
    }
}