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 http://msdn.microsoft.com/en-us/library/dd466166.aspx。 int 没有重载,因此您需要转换为 double 或小数。你的代码最终看起来像这样:
var items = from c in contacts
select new ListItem
{
Value = SqlFunctions.StringConvert((double)c.ContactId).Trim(),
Text = c.Name
};
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)