我想运行一个linq查询,但我需要结果作为datatable,因为我用它来存储来自不同查询的记录在同一个viewstate对象中。使用DataContext从LINQ查询填充DataTable最快的方法
以下两个版本编译,但返回一个空集。确切的错误是“值不能为空 参数名称:源”。 (是的,我已经检查有数据):
MyDatabaseDataContext db = new MyDatabaseDataContext(conn);
IEnumerable<DataRow> queryProjects =
(from DataRow p in db.STREAM_PROJECTs.AsEnumerable()
where p.Field<int>("STREAM_ID") == StreamID
select new
{
PROJECT_ID = p.Field<int>("PROJECT_ID"),
PROJECT_NAME = p.Field<string>("PROJECT_NAME")
}) as IEnumerable<DataRow>;
DataTable results = queryProjects.CopyToDataTable<DataRow>();
...
//(from p in db.STREAM_PROJECTs.AsEnumerable()
//where p.STREAM_ID == StreamID
//select new
//{
// p.PROJECT_NAME,
// p.PROJECT_ID
//}) as IEnumerable<DataRow>;
在此thread的例子似乎并没有在这种情况下,以工作,要么。
我想我可以运行一个SQL查询命令的老式的方式,但不是linq应该更快?
我看 - 所以它只是隐藏InvalidCastException的?那么我如何才能将它放入数据表? – JumpingJezza 2011-02-10 04:23:42