![]() |
|
|
Регистрация Восстановить пароль |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
![]() |
|
|
Опции темы | Поиск в этой теме |
![]() |
#1 |
Регистрация: 21.03.2009
Сообщений: 8
|
![]()
Здравствуйте.
Возникла проблема с отображением порядка строк в дочерней таблице. Или проблема в DBGrid? Как с этим бороться? Подскажите плз, если кто знает... Вот нормальное отображение строк в таблице(Все дочерние строки прикреплённые к строке главной таблицы через поле KeyLink отображаются корректно: ![]() Но постоянно возникает "БАГ" - одна срока в главной таблице имеет некорректное отображение строк в дочерней таблице, причём сколько не удалял, сколько новых не добавлял, всегда она присутствует. То там, то сям.... : ![]() В результате в таблицах у одного юзера всегда перепутаны числа и дни недели(идут не попорядку), и это плохо ![]() Проект ваяю на Делфи. Всем заранее спасибо... ![]() ![]() Последний раз редактировалось Vitek.klaster; 25.08.2009 в 22:00. |
![]() |
![]() |
![]() |
#2 |
Форумчанин
Регистрация: 06.01.2009
Сообщений: 340
|
![]()
Как заполняешь таблицы?
Если пишешь свои sql-запросы, то в запросе отсортируй по дате и все.
Истинный успех – это то, что Вы сделали в сравнении с тем, что могли бы сделать.
Никогда не бойся делать то, что ты не умеешь. Помни, ковчег был построен любителем. Профессионалы построили "Титаник". |
![]() |
![]() |
![]() |
#3 | |
Регистрация: 21.03.2009
Сообщений: 8
|
![]() Цитата:
Эта функция не пашет: "TimeTable1.IndexFieldNames:='Дата' ;" при попытке сортировки дочерней таблицы данные в ней перестают отображаться. Мож по другому можно отсортировать??? ![]() |
|
![]() |
![]() |
![]() |
#4 |
Форумчанин
Регистрация: 06.01.2009
Сообщений: 340
|
![]()
Даты и дни недели вносишь сам?
Может ошибка в том, что на приведенном скриншоте суббота и воскресенье с датами 01.08.2009 и 02.08.2009 вставлены не на свое место, сейчас выводит с последовательным увеличением дат, и у понедельника должно быть 01.08.2009, а у него 03.08.2009, т.е. надо убрать суббота и воскресенье и все дни сдвинуть вверх.
Истинный успех – это то, что Вы сделали в сравнении с тем, что могли бы сделать.
Никогда не бойся делать то, что ты не умеешь. Помни, ковчег был построен любителем. Профессионалы построили "Титаник". Последний раз редактировалось Daramant; 26.08.2009 в 00:38. |
![]() |
![]() |
![]() |
#5 |
Регистрация: 21.03.2009
Сообщений: 8
|
![]()
Даты и дни недели вводятся автоматически, вычисляются из периода выбранного в DateTimePicker, когда строки создаются дочерняя таблица с датами, для всех строк главной таблицы отображается корректно. Но после первого закрытия всего приложения и открытия его заново, строки дочерней таблицы для одного из "Юзеров" смещаются, например как на "скриншоте". Короче когда строки создаются - ВСЁ ГУД! Закрыл, открыл приложение - Смещаються строки.
Вот видео записал 2 мб. мож там понятнее будет. http://video.yandex.ru/users/uncle-vitek/view/1 Причём дата с днём недели совпадает везде, просто строки меняются местами... ![]() Последний раз редактировалось Vitek.klaster; 26.08.2009 в 10:07. |
![]() |
![]() |
![]() |
#6 | |
Форумчанин
Регистрация: 06.01.2009
Сообщений: 340
|
![]() Цитата:
Я обычно все делал через sql-запросы, поэтому мне трудно сказать, почему у тебя возникает такая проблема. Какие компоненты используешь? Если ADOTable, то у него есть свойство Sort, попробуй установить его у дочерней таблицы. Это будет: Код:
Истинный успех – это то, что Вы сделали в сравнении с тем, что могли бы сделать.
Никогда не бойся делать то, что ты не умеешь. Помни, ковчег был построен любителем. Профессионалы построили "Титаник". |
|
![]() |
![]() |
![]() |
#7 |
Регистрация: 21.03.2009
Сообщений: 8
|
![]()
Sort не помог, после его использования связь главной и дочерней таблицы теряется, и данные в дочерней таблице перестают отображаться.
А через sql-запросы? Это как выглядеть будет? Или надо какие-нить другие компоненты использовать? ![]() |
![]() |
![]() |
![]() |
#8 | |
Форумчанин
Регистрация: 06.01.2009
Сообщений: 340
|
![]() Цитата:
Теперь, чтобы вывести данные в DBGrid, пишем: Код:
Теперь в главном DBGrid обрабатываем событие клика мыши, определяем на какой строке оно было сделано и в дочернюю DBGrid, тем же способом выводим данные, только нужен другой компонент query. P.S. просто в твоем случае, это все делалось автоматически и данный вариант может показаться чуть сложнее и требующий написания большего кол-ва кода.
Истинный успех – это то, что Вы сделали в сравнении с тем, что могли бы сделать.
Никогда не бойся делать то, что ты не умеешь. Помни, ковчег был построен любителем. Профессионалы построили "Титаник". |
|
![]() |
![]() |
![]() |
#9 |
Регистрация: 21.03.2009
Сообщений: 8
|
![]()
Угу, спс, попробую... Сегодня уже правда некогда, а завтра я с ентим разберусь..... и отпишусьььь.....
................... М-м- да-а... Попробовал и понял, что нифига я в TADOQuery и SQL-запросах не понимаю. Пойду читать литературу по SQL ![]() ![]() Последний раз редактировалось Stilet; 28.08.2009 в 08:18. |
![]() |
![]() |
![]() |
#10 | |
Форумчанин
Регистрация: 06.01.2009
Сообщений: 340
|
![]() Цитата:
Просто надо продумать структуру, написать пару своих классов, скрывающих детали, и таким образом работать будет ни чуть не сложнее чем раньше. Удачи.
Истинный успех – это то, что Вы сделали в сравнении с тем, что могли бы сделать.
Никогда не бойся делать то, что ты не умеешь. Помни, ковчег был построен любителем. Профессионалы построили "Титаник". |
|
![]() |
![]() |
![]() |
|
![]() |
||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
Отображение через несколько DBGRID | Sparky | БД в Delphi | 10 | 26.08.2009 10:13 |
Отображение связанных полей в dbgrid | Deight | БД в Delphi | 5 | 19.04.2009 00:42 |
Отображение в форме и таблице двух столбцов подстановок | smoky | Microsoft Office Access | 5 | 01.07.2008 09:27 |
отображение иконок в DBGrid | Yoger | БД в Delphi | 3 | 04.03.2007 02:33 |