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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 23.12.2010, 19:53
goonia91 goonia91 вне форума
Прохожий
 
Регистрация: 23.12.2010
Сообщения: 8
Репутация: 10
Восклицание Связывание БД в Access

Здраствуйте! Помогите плиз вот с такой трудностью.
я создал и подключил базу в делфи. Можно ли сделать вот так: выбрать поле в базе и по нажатию двух щелчков мыши открыть другую БД и вносить туда данные?
НАПРИМЕР:
У мя есть файл *.mdb. Есть 2 таблицы: рейсы и пассажиры.
Я подключил БД в делфи через dbgrid. Открыта таблица рейсов. Выбираем поле и нажимаем 2 раза ЛКМ. После чего открывается таблица пассажиров и в нее заносим информацию о пассажире.
ЗАРАНЕЕ БЛАГОДАРЕН
Ответить с цитированием
  #2  
Старый 23.12.2010, 20:39
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Вы немножко путаете понятия БД(база данных) - это набор таблиц, запросов и правил их объединяющих. Поэтому базу нельзя подключить через DBGrid, но можно отобразить в DBGrid таблицу/запрос из базы.
То что вы хотите, вы не сделаете только с помощью 2 таблиц. Вам необходима третья таблица в которой будет хранится информация о ключевых полях из таблицы рейсы и пассажиры. А обработать двойной клик можно в событии грида OnDblClick
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #3  
Старый 23.12.2010, 20:51
stil stil вне форума
Новичок
 
Регистрация: 24.11.2010
Сообщения: 91
Репутация: 41
По умолчанию

Цитата:
Сообщение от Страдалецъ
Вы немножко путаете понятия БД(база данных) - это набор таблиц, запросов и правил их объединяющих. Поэтому базу нельзя подключить через DBGrid, но можно отобразить в DBGrid таблицу/запрос из базы.
То что вы хотите, вы не сделаете только с помощью 2 таблиц. Вам необходима третья таблица в которой будет хранится информация о ключевых полях из таблицы рейсы и пассажиры. А обработать двойной клик можно в событии грида OnDblClick
Почему нельзя если в Table Пассажиров в MasterSource указать DataSource рейсы и связать ключевые поля.
Ответить с цитированием
  #4  
Старый 23.12.2010, 20:53
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Потому-что у вас Пассажир в этом случае сможет полететь только на одном рейсе.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #5  
Старый 23.12.2010, 21:02
Аватар для s0Creator
s0Creator s0Creator вне форума
Местный
 
Регистрация: 20.02.2008
Адрес: Московская область
Сообщения: 420
Репутация: 884
По умолчанию

В общем то Страдалецъ прав.
Но можно обойтись и двумя таблицами, как хочет goonia91, только сведения о пасажирах, вылетевших повторно будут дублироваться.
А если идти по пути Страдальца - то может и трех таблиц не хватить.
Смотря какие данные о пасажире писать.
А вдруг он успел паспорт поменять?
Ответить с цитированием
  #6  
Старый 23.12.2010, 21:18
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Для связки пассажиров с рейсом хватит и одной вспомогательной таблицы:
КодПассажира, КодРейса, ДатаВылета
В этом случае, мы можем одного и того-же пассажира спокойно помещать на разные рейсы, на один рейс но в разные дни просто добавляя новую запись.
Цитата:
А вдруг он успел паспорт поменять?
А если автор соединит 2 разные сущности Лицо,Документ в одной таблице, то это будет ошибка проектирования БД.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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