С Новым годом! Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
 Аватар для Vladilena
7 / 7 / 1
Регистрация: 11.05.2012
Сообщений: 51

В таблице datatable отсортировать данные по двум полям "BRIEF_DESCRIPTION" и "LOGICAL_NAME"

12.05.2012, 02:23. Показов 2083. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Помогите мне с такой проблемой. Мне необходимо в таблице datatable отсортировать данные по двум полям "BRIEF_DESCRIPTION" и "LOGICAL_NAME". (Либо группировать по этим полям, не знаю как лучше сделать). затем для каждой такой группы отсоритивать записи по полю "OPEN_TIME".

Добавлено через 22 секунды
Как я потом смогу обращаться к каждой записи каждой группы? Суть в том, что в таблице есть еще поле "CLOSE_TIME" и эти интервалы времени для каждого BRIEF_DESCRIPTION" + "LOGICAL_NAME" могут пересекаться. И мне необходимо их объединить. Но для этого надо предварительно отсортировать дану открытия для каждой группы, поскольку я буду объединять пересекающиеся интервалы только в пределах группы.
вроде бы получилось объяснить, что мне надо. Помогите, пожалуйста

Добавлено через 13 секунд
Пробовала сортировать так:

C#
1
 var sortedList = dataSet1.Table2.OrderBy(c => c["BRIEF_DESCRIPTION"]).ThenBy(c => c["LOGICAL_NAME"]).ThenBy(c => c["OPEN_TIME"]).CopyToDataTable();
Но опять же не знаю как потом обращаться к каждой дате определенной группе.
Объединение интервалов предполагаю проводить так:

C#
1
2
3
4
5
6
7
for (int i = 1; i < sortedList.Count() + 1; i++)
            {
                if (i == sortedList.Count()) { unionlist.Add(new Interval { date_start = dn, date_end = de }); }
                else
                    if ((sortedList[i].date_start) < de) { de = sortedList[i].date_end; }
                    else { unionlist.Add(new Interval { date_start = dn, date_end = de }); dn = sortedList[i].date_start; de = sortedList[i].date_end; };
            }
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.05.2012, 02:23
Ответы с готовыми решениями:

ArrayList отсортировать по двум полям
Есть ArrayList обьектов, надо отсортировать по двум полям, сначала по дате а потом по времени и вывести все в порядке возрастания даты и...

Сортировка по двум полям в таблице
Есть страничка gsp. С результатами поиска в виде таблицы. Есть сортировка по колонке &quot;Звездность&quot;, как сделать так, чтобы при...

Поиск данных в таблице по двум полям
Здрасвтуйте. Подскажите как оргинизовать поиск из двух полей Edit Пользователь вводит в 1 поле Начальную станцию а во втором конечную....

6
 Аватар для Vladilena
7 / 7 / 1
Регистрация: 11.05.2012
Сообщений: 51
14.05.2012, 05:41  [ТС]
Тема актуальна... ну может хоть кто-нибудь знает???
0
 Аватар для nio
6050 / 3460 / 336
Регистрация: 14.06.2009
Сообщений: 8,136
Записей в блоге: 2
14.05.2012, 09:56
Vladilena, если данные приходят в datatable с БД, то лучше провести все манипуляции уже в запросе выборки, так будет проще.
Если всё-таки нужно на стороне клиента, то оптимальным будет построение LINQ-запроса.
0
 Аватар для Vladilena
7 / 7 / 1
Регистрация: 11.05.2012
Сообщений: 51
14.05.2012, 10:12  [ТС]
Конечно, понимаю, что на сервере операции с данными проводились бы гораздо быстрее. Но мне надо именно у клиента производиться все действия.
Кстати, проблему эту я решила спасибо, хоть кто-то откликнулся
0
 Аватар для nio
6050 / 3460 / 336
Регистрация: 14.06.2009
Сообщений: 8,136
Записей в блоге: 2
14.05.2012, 10:16
Цитата Сообщение от Vladilena Посмотреть сообщение
Кстати, проблему эту я решила
Если не секрет, выложи решение. Может пригодится кому-нибудь
0
 Аватар для Vladilena
7 / 7 / 1
Регистрация: 11.05.2012
Сообщений: 51
14.05.2012, 10:25  [ТС]
Конечно) Наверное, коряво решила, но это работает
C#
1
2
3
4
5
6
7
8
            var z = dataSet1.Table2.OrderBy(c => c.BRIEF_DESCRIPTION).ThenBy(c => c.LOGICAL_NAME).ThenBy(c => c.OPEN_TIME).ToList();
 
           DateTime dn; DateTime de;
           dn = Convert.ToDateTime(z.ElementAt(0).OPEN_TIME.ToString());
           de = Convert.ToDateTime(z.ElementAt(0).CLOSE_TIME.ToString());
           String Group; String atm;
           Group = z.ElementAt(0).BRIEF_DESCRIPTION.ToString();
           atm =  z.ElementAt(0).BRIEF_DESCRIPTION.ToString();
1
 Аватар для Vladilena
7 / 7 / 1
Регистрация: 11.05.2012
Сообщений: 51
15.05.2012, 02:27  [ТС]
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
for (int i = 1; i < (z.Count + 1); i++)
               {
                   if (i == z.Count) { unionlist.Add(new Interval { date_start = dn, date_end = de, Atm = atm, Descrip=Group, prostoi = (de-dn).ToString() }); }
                   else
                       if (z.ElementAt(i).LOGICAL_NAME.ToString() != z.ElementAt(i - 1).LOGICAL_NAME.ToString()) 
                       {de = Convert.ToDateTime(z.ElementAt(i-1).CLOSE_TIME.ToString());
                       Group = z.ElementAt(i-1).BRIEF_DESCRIPTION.ToString();
                       atm = z.ElementAt(i-1).LOGICAL_NAME.ToString();
                       unionlist.Add(new Interval { date_start = dn, date_end = de, Atm = atm, Descrip = Group, prostoi = (de - dn).ToString() });
                       dn = Convert.ToDateTime((z.ElementAt(i).OPEN_TIME.ToString()));
                       de =  Convert.ToDateTime(z.ElementAt(i).CLOSE_TIME.ToString());
                       Group = z.ElementAt(i).BRIEF_DESCRIPTION.ToString();
                       atm = z.ElementAt(i).LOGICAL_NAME.ToString();
                       }
Добавлено через 15 часов 40 минут
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
 else
                           if (Convert.ToDateTime((z.ElementAt(i).OPEN_TIME.ToString())) < de) 
                           { de = Convert.ToDateTime((z.ElementAt(i).CLOSE_TIME.ToString()));
                           Group = z.ElementAt(i).BRIEF_DESCRIPTION.ToString();
                           atm = z.ElementAt(i).LOGICAL_NAME.ToString();
                           }
                           else
                           {
                               unionlist.Add(new Interval { date_start = dn, date_end = de, Atm = atm, Descrip = Group, prostoi = (de - dn).ToString() });
                               dn = Convert.ToDateTime((z.ElementAt(i).OPEN_TIME.ToString()));
                               de = Convert.ToDateTime((z.ElementAt(i).CLOSE_TIME.ToString()));
                           };
               }
Это продолжение...)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.05.2012, 02:27
Помогаю со студенческими работами здесь

Отсортировать список по двум текстовым полям, не используя Linq
Как отсортировать список по двум полям и оба поля ( и Pole1(string) и Pole2(string)) по убыванию? Linq не использовать ...

Как отсортировать список по двум полям и оба поля по убыванию?
Как отсортировать список по двум полям и оба поля ( и Pole1 и Pole2) по убыванию? В данном случае Pole1 по убыванию, а Pole2 по...

Отсортировать данные в DataTable по алфавиту по определенному столбцу
Каким образом можно это осуществить?

Отсортировать в списке данные о людях по определённым полям
Помогите пожалуйста) Нужно: Отсортировать данные о людях по определённым полям. Проблема: Данные которые я ввожу, не добавляются в список...

Как проверить, есть ли данные в таблице DataTable
Есть вот такои код Как проверить, есть ли данные в таблице DataTable, которая принадлежит DataSetСпасибо! ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru