|
|
Регистрация Восстановить пароль |
Повторная активизация e-mail |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
|
Опции темы | Поиск в этой теме |
09.03.2011, 11:39 | #1 |
Новичок
Джуниор
Регистрация: 09.03.2011
Сообщений: 2
|
Подстановка данных сразу из 4 таблиц в одну в С++ Builder 6
Имеется:
1. База данных преподавателей и студентов в MS SQL Server 2005 2. В ней находится 5 таблиц: Факультеты, Группы, Преподаватели, Предметы и Основная. 3. Поля в первых 4 таблицах соответствуют их названиям (не считая целочисленные ключевые поля-идентификаторы). В них просто перечислены все группы, все преподаватели, все предметы и все факультеты 4. Последняя таблица состоит из 4 полей с теми же именами Задача: При введении данных в поля Основной таблицы необходимо обеспечить подстановку из таблиц Факультеты, Группы, Преподаватели и Предметы в соответствующие поля, т.е. чтобы не вводить полностью имя препода, который ведёт один из своих предметов у определённой группы на таком-то факультете, а обеспечить возможность выбора данных из динамически формирующегося списка при, скажем, установке курсора в нужное поле (это вообще было бы идеально), т.е. как в конструкторе - собрать Основную таблицу по деталям из четырёх других. Поскольку связь в Основной таблице идёт многие ко многим, то, пожалуй, будет надобность создавать промежуточные таблицы Вопрос: Существуют ли способы, какие-либо select-запросы или ещё что-то, чтобы это можно было осуществить? |
24.03.2011, 23:20 | #2 |
Участник клуба
Регистрация: 06.04.2009
Сообщений: 1,524
|
Ну разумеется
Смотрите в сторону LEFT/RIGHT/INNER JOIN На примере твоей БД(если я правильно понял структуру) table_fak - Факультеты (поле названия name) table_group - Группы (поле названия name) table_prep - Преподы (поле названия fio) table_pred - Предметы (поле названия title) table_main - Основная Пусть ключевые поля везде будут ID (автоинкремент), а поля со связями на таблицу <имя_таблицы_id>, например table_prep_id. Все примеры для MySQL. Для MS SQL Server их необходимо соответственно подправить Тогда запрос на выборку будет таким (ну, в сильно упрощенном варианте) Код:
Код:
Код:
Код:
Код:
Код:
Во вложении лог консоли для MySQL и скрипт с SQL запросом. Ну и дамп БД (так на всякий) Удачи! P.S. Настоятельно рекомендую подробней изучить SQL. Последний раз редактировалось psycho-coder; 24.03.2011 в 23:23. |
Похожие темы | ||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
Объединение нескольких таблиц в одну книгу | Gregory_Colbert | Microsoft Office Excel | 6 | 14.09.2010 10:24 |
Выборка и подстановка данных. | HIC | БД в Delphi | 10 | 10.09.2009 11:34 |
сведение данных из разных таблиц в одну | SingleSpart | Microsoft Office Excel | 2 | 04.08.2009 17:04 |
Объединение нескольких таблиц в одну (по определенному параметру) | iona | БД в Delphi | 13 | 18.06.2009 19:34 |
Сведение нескольких таблиц в одну | Sega | Microsoft Office Excel | 3 | 05.08.2008 15:21 |