Форум по 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 разные сущности Лицо,Документ в одной таблице, то это будет ошибка проектирования БД.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #7  
Старый 23.12.2010, 21:22
goonia91 goonia91 вне форума
Прохожий
 
Регистрация: 23.12.2010
Сообщения: 8
Репутация: 10
По умолчанию

Помогите плиз с кодом!!!)
Ответить с цитированием
  #8  
Старый 23.12.2010, 21:22
Аватар для s0Creator
s0Creator s0Creator вне форума
Местный
 
Регистрация: 20.02.2008
Адрес: Московская область
Сообщения: 420
Репутация: 884
По умолчанию

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

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

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

Последний раз редактировалось s0Creator, 23.12.2010 в 21:31.
Ответить с цитированием
  #11  
Старый 23.12.2010, 21:26
goonia91 goonia91 вне форума
Прохожий
 
Регистрация: 23.12.2010
Сообщения: 8
Репутация: 10
По умолчанию

поля:
Серия и номер паспорта
ФИО
Место
Ответить с цитированием
  #12  
Старый 23.12.2010, 21:38
Аватар для s0Creator
s0Creator s0Creator вне форума
Местный
 
Регистрация: 20.02.2008
Адрес: Московская область
Сообщения: 420
Репутация: 884
По умолчанию

goonia91 - а у тебя хоть что-то есть?
Если есть выкладывай - или предлагаешь тебе с нуля написать?
И какая Delphi ?
И для чего - всмысле можно попроще, по моей моделе - для зачета наверно сойдет.
Можно как Страдалец нарисовал, только за сущность принять "паспортные данные пассажира", тогда проверка старых записей по номеру паспорта.
Но все равно придется немного помозговать.
Да и я сегодня не смогу написать - решаю проблемму с TADOConnection - боюсь какбы всю системму не пришлось переустанавливать

Последний раз редактировалось s0Creator, 23.12.2010 в 21:46.
Ответить с цитированием
  #13  
Старый 23.12.2010, 21:48
goonia91 goonia91 вне форума
Прохожий
 
Регистрация: 23.12.2010
Сообщения: 8
Репутация: 10
По умолчанию

Мне надо сделать модернизацию моего прошлого курсового. А прошлый курсовой был простенький. У мя было 5 таблиц, которые открывались по кнопке.)
А сюда обратился за помощью, т.к. понятия не имею как это можно сделать. Я вобще думал что это мои фантазии,я и не знал что так мона делать))))

ПОМОГИТЕ ПЛИЗ!!! НАДО ОЧЕНЬ КАК!!!

DELPHI 7

Мне в принцыпе чтоб только открывало таблицу и записывало туда.

Последний раз редактировалось goonia91, 23.12.2010 в 21:54.
Ответить с цитированием
  #14  
Старый 24.12.2010, 20:43
goonia91 goonia91 вне форума
Прохожий
 
Регистрация: 23.12.2010
Сообщения: 8
Репутация: 10
По умолчанию

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

Цитата:
Мне надо сделать модернизацию моего прошлого курсового.
И где оно?
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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