Модераторы: gambit
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Сортировка в GridView, по двум колонкам 
V
    Опции темы
fear
Дата 15.7.2007, 13:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 171
Регистрация: 16.4.2006

Репутация: нет
Всего: 1



Есть GridView, который отображает данные о заказчиках, имеюся колонки имя, фамилия и т.д. Как выполнить сортировку по имени-фамилии? Т.е. отсортировать в первую очередь по имени во вторую по фамилии (Например, "Сергей Николов" должен следовать за "Сергей Арестанов").
PM MAIL   Вверх
tol05
Дата 15.7.2007, 13:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Участник Клуба
Сообщений: 1632
Регистрация: 21.12.2006
Где: Харьков

Репутация: 34
Всего: 170



читай 
GridView.SortExpression 
GridView.SortDirection


--------------------
На хорошей работе и сны хорошие снятся.
PM MAIL   Вверх
fear
Дата 15.7.2007, 16:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 171
Регистрация: 16.4.2006

Репутация: нет
Всего: 1



А где почитать можно? Не подскажешь? ... С MSDN мы друг друга как-то не понимаем smile
PM MAIL   Вверх
Idsa
Дата 15.7.2007, 17:34 (ссылка)   | (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Участник
Сообщений: 2086
Регистрация: 5.12.2006
Где: Томск

Репутация: 15
Всего: 62



Цитата(fear @  15.7.2007,  16:06 Найти цитируемый пост)
 С MSDN мы друг друга как-то не понимаем 

Ты хочешь об этом поговорить? smile


--------------------
Мой блог: alexidsa.blogspot.com
PM MAIL ICQ   Вверх
fear
Дата 15.7.2007, 17:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 171
Регистрация: 16.4.2006

Репутация: нет
Всего: 1



Цитата(Idsa @ 15.7.2007,  17:34)
Ты хочешь об этом поговорить? smile

Боюсь длинным получится разговор smile Сейчас больше буду рад, примерчику по теме.
PM MAIL   Вверх
mr.DUDA
Дата 15.7.2007, 18:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


3D-маньяк
****


Профиль
Группа: Экс. модератор
Сообщений: 8244
Регистрация: 27.7.2003
Где: город-герой Минск

Репутация: 5
Всего: 232



Проще наверно SQL-запрос построить так, чтобы возвращало упорядоченные данные, чем грид настраивать. ИМХО.


--------------------
user posted image
PM MAIL WWW   Вверх
fear
Дата 15.7.2007, 19:06 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 171
Регистрация: 16.4.2006

Репутация: нет
Всего: 1



Нашёл решение, нужно переопределить событие sorting следующим образом.
Код

protected void GridView1_Sorting(object sender, GridViewSortEventArgs e)
{
    string oldExpression = GridView1.SortExpression;
    string newExpression = e.SortExpression;
    if (oldExpression.IndexOf(newExpression) < 0)
    {
        if (oldExpression.Length > 0)
             e.SortExpression = oldExpression + ", " + 
newExpression;
         else
             e.SortExpression = newExpression;
     }
     else
     {
         e.SortExpression = oldExpression;
     }
}


Это сообщение отредактировал(а) fear - 15.7.2007, 19:22
PM MAIL   Вверх
mr.DUDA
Дата 15.7.2007, 22:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


3D-маньяк
****


Профиль
Группа: Экс. модератор
Сообщений: 8244
Регистрация: 27.7.2003
Где: город-герой Минск

Репутация: 5
Всего: 232



Добавил в FAQ.


--------------------
user posted image
PM MAIL WWW   Вверх
fear
Дата 16.7.2007, 16:16 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 171
Регистрация: 16.4.2006

Репутация: нет
Всего: 1



Кто-нибуть пытался изменять сам способ сортировки? Чтобы поиск проводился не по алфавиту, а по другим критериям?
PM MAIL   Вверх
Mymik
Дата 16.7.2007, 19:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Участник Клуба
Сообщений: 1474
Регистрация: 12.5.2006
Где: Lamer-центер

Репутация: 50
Всего: 78



если мне не изменяет память, то сортировка происходит по критериям типа соответствующие типу данных хранящихся в колонке. Т.е. если ты хранишь там int (когда создаешь DataTable с данные для DataColumn.DataType = typeof(int)) то сортировка будет происходить по числовому принципу.


--------------------
ICQ ::            857-857
E-mail ::         mymik[at]inbox[dot]ru 
HomaPage ::  http://localhost/

:to_become_senile  :this
PM MAIL WWW ICQ   Вверх
fear
Дата 16.7.2007, 21:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 171
Регистрация: 16.4.2006

Репутация: нет
Всего: 1



С этим всё ясно. А вот как быть если тип строковый, а сортировать нужно не по алфовиту а по смыслу - не понятно ... Какой-то механизм должен существовать, не реализовывать же сортировку с нуля.
PM MAIL   Вверх
Naum
Дата 19.7.2007, 09:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 743
Регистрация: 7.9.2005
Где: Саратов, ул. Поса дского, 298

Репутация: 2
Всего: 15



Цитата(fear @  16.7.2007,  22:18 Найти цитируемый пост)
не реализовывать же сортировку с нуля.

Только так.
Цитата(fear @  16.7.2007,  22:18 Найти цитируемый пост)
не по алфовиту а по смыслу - не понятно

Ты хочешь, чтобы разработчики фреймворка знали, какой смысл каждый программист может вложить в строки в гридвью??? 



--------------------
У нас всего два праздника Новый год и ТЯПница.
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Прежде чем создать тему, посмотрите сюда:
Любитель
Mymik
mr.DUDA

Используйте теги [code=csharp][/code] для подсветки кода. Используйтe чекбокс "транслит" если у Вас нет русских шрифтов.

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Любитель, Mymik, mr.DUDA.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Разработка под ASP.NET | Следующая тема »


 




[ Время генерации скрипта: 0.1095 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.