Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
1 / 1 / 0
Регистрация: 12.08.2011
Сообщений: 111

Как реализовать структуру БД

13.01.2018, 10:18. Показов 990. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброе утро!
Есть сайт технической поддержки. И есть пользователи, которые оставляют на нем заявку в компанию. На нем есть таблица с полями: id_client(id пользователя AI, PK), name_client(Имя потльзователя), status(статус - наверное лучше сделать автоинкремент), date_r(дата регистрации).

Статусы у всех пользователей будут разные. Например:
у пользователя 1: открыто, отменено, закрыто, передано, принято.
у пользователя 2: открыто, отменено, закрыто, исполнено, в ожидании.

Статусы в любое время могут добавляться( не удаляются).
Я сделал так:
Вторая таблица такая: id_status, id_client, open, close, cancelled, sent, accepted.
id_status - AI PK, id_client - указывает на первую таблицу на пользователя, другие поля сами статусы и имеют значение enum: '0', '1' - в зависимости присутствует для пользователя ставиться 0 или 1.

Когда необходимо добавлять статус какому либо клиенту сначала ставлю 1 для нужного пользователя, а для всех других проставляю 0.

Может можно реализовать попроще?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.01.2018, 10:18
Ответы с готовыми решениями:

Как правильно реализовать общую структуру правил для игр?
Делаю игровой портал, где есть игры по заявкам и столы. Столы - фиксированные правила,...

Как реализовать структуру на js?
struct klass { char name; char klass_name; float bal; }; как реализовать такое на js и...

Как реализовать структуру
Доброго времени суток. Никак не могу скомпиллировать эту структуру. struct tree{ char inf;...

5
26 / 26 / 17
Регистрация: 23.12.2017
Сообщений: 111
13.01.2018, 19:48
Как я понимаю, все пять статусов работают по принципу "ИЛИ". То есть, активным статусом может быть только один из них.
Так может проще сделать как-то так:
SQL
1
2
3
4
5
6
7
CREATE TABLE `statuses` (
`id_status` INT(10) NOT NULL AUTO_INCREMENT,
`id_client` INT (10) NOT NULL,
`status` ENUM('open', 'close', 'cancelled', 'sent', `accepted`) NOT NULL DEFAULT 'open', -- или что там по умолчанию
PRIMARY KEY (`id_status`),
UNIQUE KEY `status_client` (`id_status`, `id_client`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
Ну, или какой engine у Вас используется.
На мой взгляд, с данными удобней работать будет.
0
1 / 1 / 0
Регистрация: 12.08.2011
Сообщений: 111
14.01.2018, 08:19  [ТС]
Дело в том, что у каждого клиента должны быть видны несколько статусов для выбора (только ему принадлежащие), а у другого клиента (другие статусы, принадлежащие именно ко второму клиенту)

Связь один ко многим
0
62 / 63 / 28
Регистрация: 10.01.2018
Сообщений: 360
14.01.2018, 11:07
Лучший ответ Сообщение было отмечено tarabukinivan как решение

Решение

tarabukinivan,

tb_status
id(pk ai) | status_name | descrip |

tb_user_status
id(pk ai) | status_id/status_name(fk) | id_user(fk)

SQL
1
SELECT status_name FROM user_status WHERE id_user = "1"
Не вариант?
0
26 / 26 / 17
Регистрация: 23.12.2017
Сообщений: 111
14.01.2018, 12:00
Лучший ответ Сообщение было отмечено tarabukinivan как решение

Решение

Цитата Сообщение от tarabukinivan Посмотреть сообщение
Дело в том, что у каждого клиента должны быть видны несколько статусов для выбора (только ему принадлежащие), а у другого клиента (другие статусы, принадлежащие именно ко второму клиенту)
Ну, так и в чём проблема? В базе записи:
SQL
1
2
3
4
5
6
7
8
-- для клиента №1:
1, 1, 'open'
2, 1, 'close'
3, 1, 'cancelled'
-- для клиента №2:
4, 2, 'open'
5, 2, 'accepted'
6, 2, 'sent'
И выводите их в dropdown list box на front-end.
Просто, наверное, смутило название поля 'status_id'... Переименовать можно.
Хотя, дело, конечно, личное. Это просто предложение.

Добавлено через 5 минут
Или связку добавить, как Sternman предлагает.
Пригодится для maintenance "statuses" table в перспективе.
Тогда записи в баже вот так выглядеть будут:
SQL
1
2
3
4
5
6
7
8
-- для клиента №1:
1, 1, 1
2, 1, 2
3, 1, 4
-- для клиента №2:
4, 2, 2
5, 2, 1
6, 2, 3
Так даже ещё гибче будет. Да и правильней, я думаю.
0
1 / 1 / 0
Регистрация: 12.08.2011
Сообщений: 111
14.01.2018, 16:19  [ТС]
Ну да, что-то типа такого должно быть.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.01.2018, 16:19
Помогаю со студенческими работами здесь

Как реализовать структуру?
Есть две структуры студент и комната в которой он проживает. Как лучше реализовать ситуацию?...

Как можно реализовать такую структуру?
Реализовать структуру данных, которая имеет все те же операции, что массив длины n, а именно •...

Как лучше реализовать структуру класса?
Есть задача создать класс авто-архив. Класс реализовал со структурой внутри класса. Создал...

Как реализовать подобную структуру заказ проще
Здравствуйте. На странице...

Как реализовать правильную структуру таблицы сотрудников, работодателей?
Есть таблица пользователей, каждый пользователь может выступать как работодателем, так и...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru