Копирование результата Linq в DataTable - PullRequest
0 голосов
/ 22 июля 2010

Какие изменения мне нужно внести, чтобы сократить выполнение этой задачи с меньшим количеством строк и лучшим подходом.

   DataTable dtStatusMsgs;
    var statusList = (
                    from items in dtInputTable.AsEnumerable()
                    where items.Field<int>("DepartmentId") == deptId
                    select new
                    {
                        statusId = items.Field<int>("StatusId"),
                        status = items.Field<string>("Status"),
                        statusOrder = items.Field<int>("StatusSortOrder"),
                        rowId = items.Field<int>("RowId")

                    }).Distinct();

    dtStatusMsgs = new DataTable();
    dtStatusMsgs.Columns.Add("StatusId", typeof(int));
    dtStatusMsgs.Columns.Add("Status", typeof(string));
    dtStatusMsgs.Columns.Add("StatusSortOrder", typeof(int));
    dtStatusMsgs.Columns.Add("RowId", typeof(int));

    foreach (var item in statusList)
        dtStatusMsgs.Rows.Add(item.statusId, item.status,item.statusOrder
                              , item.rowId);

Я хочу, чтобы это было сделано примерно так.

   DataTable dtStatusMsgs;
    var statusList = (
                    from items in dtInputTable.AsEnumerable()
                    where items.Field<int>("DepartmentId") == deptId
                    select new
                    {
                        statusId = items.Field<int>("StatusId"),
                        status = items.Field<string>("Status"),
                        statusOrder = items.Field<int>("StatusSortOrder"),
                        rowId = items.Field<int>("RowId")

                    }).Distinct();



dtStatusMsgs= statusList.CopyToDataTable<DataRow>();

А как использовать функцию Sum для любого столбца в этом коде.Я хочу увидеть пример кода для применения любой агрегатной функции

1 Ответ

1 голос
/ 04 февраля 2011
dtStatusMsgs = new DataTable();     
dtStatusMsgs.Columns.Add("StatusId", typeof(int));     
dtStatusMsgs.Columns.Add("Status", typeof(string));     
dtStatusMsgs.Columns.Add("StatusSortOrder", typeof(int));     
dtStatusMsgs.Columns.Add("RowId", typeof(int));

statusList.ForEach(p => dtStatusMsgs.Rows.Add(p.StatusId, p.Status, p.StatusSortOrder,p.RowId)); 
...