Russian Qt Forum
Ноябрь 23, 2024, 04:18
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Базы данных
>
бд связь один ко многим
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: бд связь один ко многим (Прочитано 2981 раз)
demaker
Птица говорун
Offline
Сообщений: 962
бд связь один ко многим
«
:
Август 20, 2016, 12:06 »
Никогда не писал ПО для БД. Надо написать клиента для БД.
Читал доки по QtSql но так и не понял как реализовать связь
"один ко многим". Есть класс QSqlRelationTableModel
с помощью которого можно реализовать связь "один к одному".
Не могли бы вы привести пример реализации или наставить на путь
истинный.
Записан
break
Гипер активный житель
Offline
Сообщений: 846
Re: бд связь один ко многим
«
Ответ #1 :
Сентябрь 06, 2016, 21:11 »
Мне видится только один правильный путь.
Связи задаются в БД - то есть там есть две таблице с сущностями для которых надо задать связи. Для этих таблиц обязательно наличие суррогатных первичных ключей (а я приверженец такого подхода, что суррогатный первичный ключ нужен всем и каждой таблице в любой БД). И есть третья таблица в которой и задается связь многие ко многим, через ИД-шники первых двух таблиц. То есть имеет вид
ROW_ID | TABLE_1_ROW_ID | TABLE_2_ROW_ID
ROW_ID - собственный суррогатный ключ таблицы связей
TABLE_1_ROW_ID И TABLE_2_ROW_ID - ключи связываемых таблиц
По полям TABLE_1_ROW_ID И TABLE_2_ROW_ID должен быть создан уникальный индекс
Далее для вывода на клиент - как больше нравится или запрос с джойнами или хранимая процедура, если сервер БД их поддерживает. То есть этот запрос или ХП выводит уже не ИД-шники, а данные с ними связанные в своих таблицах.
Вызов ХП или запрос кладется в QSqlQueryModel - ну и все в таблице будет видно.
НО функционал QSqlQueryModel крайне ограничен и уже добавлять и редактировать/удалять записи через нее быдет сложно, т.к. нельзя задать отдельных запросов InsertSQL, RemoveSQL и т.д. Мне пришлось для таких целей писать свою модель.
Записан
Страниц: [
1
]
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...