Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 20.05.2009, 06:45
densky densky вне форума
Прохожий
 
Регистрация: 19.04.2008
Сообщения: 23
Репутация: 10
По умолчанию Вставка Идентификатора

Доброго времени суток !
Мне снова требуется ваша помощь,уважаемые !

никак не могу понять...

У меня есть 3 таблицы... Одна главная,и и две присоединенные...
Все таблицы отображаются в в 3-х DBGrid'aх...

На отдельной форме добавляются данные в эти таблицы...
Но вот какая штука...Не добавляются идентификаторы для двух подчиненных таблиц..Т.е. поле пустое(NULL)... И В Гридах данные не отображаются...Хотя в таблицах то они есть...

Как вставлять идентитфикатор первой таблицы для двух других??
Ответить с цитированием
  #2  
Старый 20.05.2009, 11:16
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

А вы реализовали отношение Мастер - детайл ваших таблиц?
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #3  
Старый 20.05.2009, 13:17
densky densky вне форума
Прохожий
 
Регистрация: 19.04.2008
Сообщения: 23
Репутация: 10
По умолчанию

Цитата:
Сообщение от Страдалецъ
А вы реализовали отношение Мастер - детайл ваших таблиц?
Эмм...
Ну в делфи ADOTable соединены с главной... Master Source,Master Fields...

Тобишь мне нужно выбрать значение первого грида,а в остальных гридах выскакивает доп инфа,по выбранному пункту... Но при добавлении этой доп инфы не прописывается идентификатор для связи с первой таблицей..
Ответить с цитированием
  #4  
Старый 20.05.2009, 13:22
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Странно, должно работать. Скиньте кусок DFM-файла, где вы эти связи установили.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #5  
Старый 20.05.2009, 14:15
densky densky вне форума
Прохожий
 
Регистрация: 19.04.2008
Сообщения: 23
Репутация: 10
По умолчанию

Спасибо за помощь!

Я залил весь проект...=)
600 кБ всего...
вот тут
Ответить с цитированием
  #6  
Старый 22.05.2009, 03:58
densky densky вне форума
Прохожий
 
Регистрация: 19.04.2008
Сообщения: 23
Репутация: 10
По умолчанию

ну так как..?
Помогите плиз...=))))
Ответить с цитированием
  #7  
Старый 22.05.2009, 04:26
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Проект это конечно хорошо, но без БД или хотя-бы структуры таблиц вашей БД от нее толку мало.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #8  
Старый 22.05.2009, 10:07
densky densky вне форума
Прохожий
 
Регистрация: 19.04.2008
Сообщения: 23
Репутация: 10
По умолчанию

Упс...Не учел как-то..=)

Вот тут BD
Ответить с цитированием
  #9  
Старый 23.05.2009, 08:16
densky densky вне форума
Прохожий
 
Регистрация: 19.04.2008
Сообщения: 23
Репутация: 10
По умолчанию

Ответить с цитированием
  #10  
Старый 23.05.2009, 12:02
Аватар для TOJluK
TOJluK TOJluK вне форума
Местный
 
Регистрация: 25.02.2009
Адрес: Минск
Сообщения: 551
Версия Delphi: 2007
Репутация: 110
По умолчанию

Т.е. в таблицу данные попадают, а в гриде их не видно? Попробуй обновить данные с сервера путем перевода Active таблиц в False и затем в True
Ответить с цитированием
  #11  
Старый 23.05.2009, 12:14
densky densky вне форума
Прохожий
 
Регистрация: 19.04.2008
Сообщения: 23
Репутация: 10
По умолчанию

Цитата:
Сообщение от TOJluK
Т.е. в таблицу данные попадают, а в гриде их не видно? Попробуй обновить данные с сервера путем перевода Active таблиц в False и затем в True
Да нет...Суть не в том...
Таблицы соединены...т.е. в двух подчиненных таблицах отображаются данные имеющие связь по идентификатору с первой таблицей...
А при заполнении этих таблиц мне надо как-то и во вторые таблицы записать соответсвующий идентификатор...
Ответить с цитированием
  #12  
Старый 23.05.2009, 13:46
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Я ее запустил все-же.
1. Сразу крик души. Никогда! Никогда! Не подключайте базу в дизайнмоде. Проверили подключение, убедились, что все работает и отключили сразу. Окончательное подключение, только на стадии запуска приложения.
2. Используйте не клиентский, а серверный курсор где это возможно - удивитесь нсколько все шустрее станет работать.
3. А неработает это у вас потому-что, на момент применения комманды Insert/Append значение ид_маршрута еще пусто. Заполниться оно после того как вы примените Post. Смотрите что получается:
Table1.Insert - ид_маршрута = null
Table2.Insert - ид_маршрута соответственно тоже null
Table3.Insert - ид_маршрута соответственно тоже null
далее вы делаете Post
Table3.Post - ид_маршрута заноситься null
Table2.Post - ид_маршрута заноситься null
Table1.Post - ид_маршрута получает новое значение счетчика и уже не Null
т.е. сначала добавляется значение в мастер-таблицу, записывается. И только после появления реального значения в ней можно и в подчиненных таблицах делать добавления.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.

Последний раз редактировалось Страдалецъ, 23.05.2009 в 14:07.
Ответить с цитированием
  #13  
Старый 23.05.2009, 14:17
densky densky вне форума
Прохожий
 
Регистрация: 19.04.2008
Сообщения: 23
Репутация: 10
По умолчанию

Так так..=)
Делаю так:
Код:
ADOTable1.Insert;
ADOTable2.Insert;
ADOTable3.Insert;
Код:
Form1.ADOTable1.Post;
Form1.ADOTable2.Post;
Form1.ADOTable3.Post;
То по непонятной мне причине,прога ругается на то что ADOTable2:dataset not in isert mode

Как быть?
Ответить с цитированием
  #14  
Старый 23.05.2009, 16:39
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Не так. Я делал через Append, но я думаю это непринципиально.
Сначала делаете все с мастер-таблицей:
Код:
ADOTable1.Append;
...
ADOTable1.Post;
вот после этого уже можно делать что-то с подчиненными:
Код:
ADOTable2.Append;
ADOTable3.Append;
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #15  
Старый 23.05.2009, 17:42
densky densky вне форума
Прохожий
 
Регистрация: 19.04.2008
Сообщения: 23
Репутация: 10
По умолчанию

Вотоно все как !
=)))
Спасибо большое добрый человек ! ! !
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 11:22.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter