Проект DBComponents. Часть 1. Требования к проекту и базе данных

DBComponents, Qt, Iscander Che, C++

Требования к проекту

Проект реализует базу данных IT-компонентов. Планируется пока три категории: мониторы, медицинские принтеры, системные блоки. Также в функционал базы входит возможность создавать новые категории.

Проект должен состоять из двух функциональных частей – панели администратора и панели пользователя.

Панель администратора должна содержать следующие представления и инструменты:

  • список категорий и кнопку команды «Новая категория»;
  • список параметров категории и кнопки команд «Новый параметр» и «Редактировать параметр»;
  • список компонентов категории и кнопки команд «Новый компонент» и «Редактировать компонент».

По нажатии на кнопку:

  • «Новая категория» должно вызываться диалоговое окно создания новой категории компонентов, содержащее строки ввода имени категории в представлении (видимое имя) и имя категории для базы данных (только латиница плюс символ подчёркивания);
  • «Новый параметр» должно вызываться диалоговое окно создания нового параметра, содержащее строки ввода имени параметра в представлении (видимое имя) и имя параметра для базы данных (только латиница плюс символ подчёркивания), флажок «Заголовок подсписка» для указания, что параметр фиктивный и заполнению в базе данных не подлежит, и выпадающий список «Позиция в списке» с номерами позиций. По умолчанию номер позиции в списке следующий за последним существующим параметром;
  • «Редактировать параметр» должно вызываться диалоговое окно редактирования параметра, содержащее строку ввода имени параметра в представлении с ранее введённым значением;
  • «Новый компонент» должно вызываться диалоговое окно создания нового компонента, содержащее строки ввода ранее созданных параметров компонента. Если параметр не заполняется, то в базе данных этот параметр должен быть записан как «н/д» (нет данных);
  • «Редактировать компонент» должно вызываться диалоговое окно редактирования компонента, содержащее строки ввода параметров компонента с ранее введёнными значениями. Если параметр записан в базе данных как «н/д», строка ввода параметра должна быть пустой.

Панель пользователя должна содержать следующие представления и инструменты:

  • список категорий;
  • блок фильтров для компонентов, состоящий из строк ввода и/или выпадающих списков основных параметров (должно определяться программно, на уровне кода);
  • список компонентов для выбранной категории, удовлетворяющий условиям фильтров;
  • список параметров для выбранного компонента;
  • кнопку команды «Экспортировать в Excel», по нажатию на которую список параметров и значений параметров для выбранного компонента экспортируется в таблицу Excel.

Требования к базе данных

В отношении этой части у меня есть сомнения в правильности решения, в связи с чем я прошу уважаемое сообщество подтвердить мой выбор или предложить другой вариант решения. Заранее спасибо.

База данных должна использовать СУБД SQLite и содержать следующие таблицы:

  • таблица категорий компонентов components_category с полями id , name , view_name ;
  • таблицы параметров компонентов по количеству категорий parameters_<name> (где name – содержимое соответствующего поля таблицы категорий компонентов components_category ), с полями id , name , view_position , view_name , header ;
  • таблицы значений параметров компонентов по количеству категорий values_<name> (где name – содержимое соответствующего поля таблицы категорий компонентов components_category ), с полями id , <name1> , <name2> , … <nameN> (где name1 , name2 , … nameN – содержимое соответствующего поля name таблицы параметров компонентов parameters_<name> ).
We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.
IP

Я бы сделал базу в таком виде:

CREATE TABLE "components" (
"id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
"name" TEXT
);

CREATE UNIQUE INDEX "index"
ON "components" ("name" ASC);

CREATE TABLE "parameters" (
"id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
"components_id" INTEGER,
"name" TEXT NOT NULL,
FOREIGN KEY ("components_id") REFERENCES "components" ("id") ON DELETE RESTRICT ON UPDATE RESTRICT
);

CREATE TABLE "values" (
"id" INTEGER NOT NULL,
"vparameter_id" INTEGER,
"name" TEXT,
PRIMARY KEY ("id" ASC),
FOREIGN KEY ("vparameter_id") REFERENCES "parameters" ("id") ON DELETE RESTRICT ON UPDATE RESTRICT
);
Не совсем понятно назначение поля view_position, но если сильно нужно, то его можно добавить в таблицу "parameters"
Если есть такая необходимость, то можно "ON DELETE RESTRICT" заменить на "ON DELETE CASCADE", тогда при удалении строки из "components" сразу удалятся соответствующие parameters и values

CREATE UNIQUE INDEX "index"
ON "components" ("name" ASC);

Вот эти строки поясните, для чего они.

Не совсем понятно назначение поля view_position

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

при удалении строки из "components"

Т.е. то, что написано после FOREIGN KEY, относится к удалению из "components"? На данный момент удаления из "components" как такового не предполагается.

IP

CREATE UNIQUE INDEX "index"
ON "components" ("name" ASC);
индекс на поле name, дополнительно делает поле name уникальным

| Т.е. то, что написано после FOREIGN KEY, относится к удалению из "components"? На данный момент удаления из "components" как такового не предполагается.
Так и есть, помимо этого FOREIGN KEY не дает содать parameters со значением components_id если нет соответствующего значения id в components. FOREIGN KEY обеспечивает целостность данных между 2 таблицами при добавлении и удалении данных

parameters с полем view_position будет выглядеть так:
CREATE TABLE "parameters" (
"id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
"components_id" INTEGER,
"name" TEXT NOT NULL,
"view_position" INTEGER,
CONSTRAINT "fkey0" FOREIGN KEY ("components_id") REFERENCES "components" ("id") ON DELETE RESTRICT ON UPDATE RESTRICT
);

CONSTRAINT "fkey0"

А вот это для чего?

Comments

Only authorized users can post comments.
Please, Log in or Sign up
Donate

Hello, Dear Users of EVILEG!!!

If the site helped you, then support the development of the site financially, please.

You can do it by following ways:

Thank you, Evgenii Legotckoi

LP
Nov. 12, 2019, 8:22 a.m.
Lev Parhimovich

C++ - Test 006. Enumerations

  • Result:50points,
  • Rating points-4
LP
Nov. 12, 2019, 7:35 a.m.
Lev Parhimovich

C++ - Test 005. Structures and Classes

  • Result:66points,
  • Rating points-1
LP
Nov. 12, 2019, 7:26 a.m.
Lev Parhimovich

C ++ - Test 004. Pointers, Arrays and Loops

  • Result:50points,
  • Rating points-4
Last comments
b
Nov. 9, 2019, 8:28 a.m.
bastonc

спасибо ещё раз. огромное, за уделённое время
b
Nov. 9, 2019, 8:24 a.m.
bastonc

Спасибо Вам большое. Буду изучать.
Nov. 9, 2019, 5:58 a.m.
Evgenij Legotskoj

Добрый день. По первым двум вопросам вы найдёте ответ в этой статье - PyQt5 - Урок 008. Работа с QTableWidget (Обновление урока 006) Что касается последнего вопроса, то я вам…
Nov. 9, 2019, 2:50 a.m.
Evgenij Legotskoj

Как и обещал, вы можете посмотреть новую статью QML - Урок 037. Кастомизация кнопок в QML (Обновление урока 002) . Там же найдёте ссылку на Git репозиторий. Не забудьте поставить звёз…
b
Nov. 8, 2019, 7:40 a.m.
bastonc

Приветствую. Подскажите пожалуйста пару моментов. 1. Как сделать столбец не редактируемый, а остальные ячейки остаются редактируемыми 2. Как оталвливать события двойного клика для реда…
Now discuss on the forum
Nov. 14, 2019, 4:23 a.m.
Ruslan Polupan

Я уже понял это, ковыряюсь сижу....
Nov. 14, 2019, 3:56 a.m.
Evgenij Legotskoj

Добрый день. Я уже очень давно не создавал инсталляторы, но на данный момент поведение Maintenance Tool выглядит так, что он имеет свой собственный пакет в репозитории. Но честно, я могу с…
Nov. 14, 2019, 2:16 a.m.
Ruslan Polupan

посмотрите тут http://www.prog.org.ru/topic_6637_15.html И гдето на Гитхабе я видел исходни класса который это реализует
Nov. 13, 2019, 9:33 a.m.
Pavel.K

Приложение трэкинг задач. Есть вложения. Добавляем вложение и отправляем его на сервер. Для синхронного вызова методов в синхронизации, используем QEventLoop при отправке вложений. В момент син…
Nov. 13, 2019, 3:13 a.m.
Evgenij Legotskoj

Добрый день. Думаю, что да. Выбранный стиль можно подгружать при запуске программы. Во всяком случае, есть такой пример на C++ - Controls Gallery . И там есть такой код #incl…
EVILEG
About
Services
© EVILEG 2015-2019
Recommend hosting TIMEWEB