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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 04.02.2014, 19:43
govorun govorun вне форума
Новичок
 
Регистрация: 30.10.2013
Сообщения: 60
Версия Delphi: delphi 7
Репутация: 10
По умолчанию Застрял на структуре базы

Необходимо создать базу (Access) для музея. Народ будет тащить в него всякое добро, потом это добро будет передаваться на хранение, потом на реставрацию, потом выставляться на витрину.
К базе буду рисовать оболочку в Delphi
Не могу придумать структуру базы чтобы пользователь, когда притащат добро, ввел:

Петров
топор
грабли

Иванов
вилы
кол
пистолет
....
Фамилия должна вводиться и только один раз, а не выбираться из списка.
Т.е. ввел в edit 'Петров' и тут же в другой edit ввел 'топор', кнопку нажал, топор сохранился, в этот же edit вводим 'грабли' (фамилию не трогаем)

Попробовал связанные таблицы.... Не подходит. Приходится каждый раз выбирать ФИО. А нужно один раз ввести ФИО и сразу вводить предметы.
Потом ввести другую ФИО и опять предметы.
Ответить с цитированием
  #2  
Старый 05.02.2014, 09:23
Аватар для Mrak
Mrak Mrak вне форума
Местный
 
Регистрация: 26.01.2013
Адрес: МО
Сообщения: 438
Версия Delphi: XE2
Репутация: 17
По умолчанию

вопрос больше не по структуре, а по интерфейсу клиентской части

структура:

таблица клиентов:
id surname
1 Иванов
2 Петров
...

таблица предметов:
surname_klient predmet
Иванов Вилы
Петров Нож
Иванов Топор

Связь один-ко-многим

При добавлении запрос вида:
Код:
Query.SQL.text:='INSERT INTO tabl_predmet (id_klient, predmet) VALUES ("' +
 edit_surname.text + '", "' + comboBox_predmet.text + '")';

Можно немного упростить, пихая во вторую таблицу не фамилии, а их id (плюс не будет неоднозначности при совпадении фамилий)
__________________
Я за здоровый экстрим!
Спасибо за "спасибо")

Последний раз редактировалось Mrak, 05.02.2014 в 10:33.
Ответить с цитированием
  #3  
Старый 05.02.2014, 21:53
govorun govorun вне форума
Новичок
 
Регистрация: 30.10.2013
Сообщения: 60
Версия Delphi: delphi 7
Репутация: 10
По умолчанию

Цитата:
Сообщение от Mrak
вопрос больше не по структуре, а по интерфейсу клиентской части

структура:

таблица клиентов:
id surname
1 Иванов
2 Петров
...

таблица предметов:
surname_klient predmet
Иванов Вилы
Петров Нож
Иванов Топор

Связь один-ко-многим

При добавлении запрос вида:
Код:
Query.SQL.text:='INSERT INTO tabl_predmet (id_klient, predmet) VALUES ("' +
 edit_surname.text + '", "' + comboBox_predmet.text + '")';

Можно немного упростить, пихая во вторую таблицу не фамилии, а их id (плюс не будет неоднозначности при совпадении фамилий)

Не понял, а откуда будет клиент браться?
Ответить с цитированием
  #4  
Старый 06.02.2014, 10:27
Аватар для Mrak
Mrak Mrak вне форума
Местный
 
Регистрация: 26.01.2013
Адрес: МО
Сообщения: 438
Версия Delphi: XE2
Репутация: 17
По умолчанию

ну придет, наверное, пешком из дома

если я правильно понял, то базы клиентов нет и она должна создаваться при добавлении предмета. Ну тогда вообще убрать таблицу клиентов и работать только с одной таблицей посредством вышеприведенного запроса

так же советую посмотреть элементарные программки, работающие с БД, тогда многие вопросы отпадут (классика - книжный магазин)
__________________
Я за здоровый экстрим!
Спасибо за "спасибо")
Ответить с цитированием
Этот пользователь сказал Спасибо Mrak за это полезное сообщение:
Alegun (06.02.2014)
  #5  
Старый 06.02.2014, 11:13
Аватар для Alegun
Alegun Alegun вне форума
LMD-DML
 
Регистрация: 12.07.2009
Адрес: Богородское
Сообщения: 3,025
Версия Delphi: D7E
Репутация: 1834
По умолчанию

Тогда здесь структура вообще не нужна - вам достаточно одной таблицы в базе с двумя текстовыми полями: Клиент и Предметы. Всё. Кидаете два едита на форму, тот что будет с клиентом связан не обновляете и каждый раз при добавлении новой записи записываете их значение в таблицу. Много избыточной инфы, зато надёжно. А дальше выборка если нужна - Mrak уже запрос любезно вам выложил. И нечего голову ломать
Ответить с цитированием
Этот пользователь сказал Спасибо Alegun за это полезное сообщение:
govorun (06.02.2014)
  #6  
Старый 10.02.2014, 19:26
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

А теперь вопрос. А нафик вообще что-то вносить в такую базу? Какая конечная цель всего этого учета?
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter