Перейти до

Требуется внесение таблицы "все-ко-всем"


Рекомендованные сообщения

Вопрос дополнения базы данных и биллинга таблицей "все-ко-всем", продиктованы следующими потребностями.

Есть модуль "Филиалы".

При подключении данного модуля возникает следующая проблема.

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

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

Далее филиал не может создавать филиал.

 

Такие задачи решаются созданием таблицы "все-ко-всем" в которой формируется каскадное вложение филиалов и связкой соответствующих таблиц сервисов.

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

Более того филиал сможет создавать свои филиалы, контролировать в них данные.

 

Приветствуется любая критика и предложения,

помощь в консультации и программировании.

Спонсирование заинтересованных сторон, приветствуется.

Відредаговано pavlabor
Ссылка на сообщение
Поделиться на других сайтах
5 минут назад, olsasha сказал:

Думаю логично будет назвать например - "матрица прав и доступа" для пользователя.

Наверно расширенная "матрица прав и доступа" больше подойдет к разделу "Права, введение расширенной настройки прав"

 

Здесь может правильней назвать "строитель дерева".

Работает он как связка  адреса "город + улица + дом".

Задача работа филиалов.

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

При этом каждая ветка филиалов, позволит например просматривать исключительно свой склад и склады филиалов.

 

Практическое решение.

Есть оператор у которого есть сети в нескольких городах, при чем в каждом городе по несколько районов и там свой филиал, более того руководство районного филиала решило в качестве стимулирования работников отдать сетки на Аутсо́рсинг мастерам с отчислением не зарплаты а процента от оборота.

При этом данная таблица позволяет организовать контроль за активами только свои и всех нижестоящих филиалов.

При этом филиал не сможет смотреть активы дирекции и чужих филиалов, а будет просматривать только свои активы и активы своих филиалов.

Последний филиал, будет видеть только свои активы.

Ссылка на сообщение
Поделиться на других сайтах
8 часов назад, pavlabor сказал:

Вопрос дополнения базы данных и биллинга таблицей "все-ко-всем", продиктованы следующими потребностями.

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

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

Сорри, но когда-то в 2000-х решал подобную проблему ...

Ваше видение, ИМХО, не совсем верное :(

Тут нет таблиц "все-ко-всем" ...

Есть древовидная структура с разграничением прав доступа по множителю на уровень "ветки" ... Начиная от Контрагента (или объеденения онных)

Как правило такая структура организуется на уровне программного кода PSQL обычными union запросами ...  (Как Вы выразились на стороне сервера)

Сначала выбираются разрешительные ветки контрагентов (и/или из адресов обслуживания), а потом уже всё что с ними связано ...

Ссылка на сообщение
Поделиться на других сайтах
Опубліковано: (відредаговано)
11 часов назад, Stroj сказал:

Сорри, но когда-то в 2000-х решал подобную проблему ...

Ваше видение, ИМХО, не совсем верное :(

Тут нет таблиц "все-ко-всем" ...

Есть древовидная структура с разграничением прав доступа по множителю на уровень "ветки" ... Начиная от Контрагента (или объеденения онных)

Как правило такая структура организуется на уровне программного кода PSQL обычными union запросами ...  (Как Вы выразились на стороне сервера)

Сначала выбираются разрешительные ветки контрагентов (и/или из адресов обслуживания), а потом уже всё что с ними связано ...

 

Собственно это стандартная задача "SQL для начинающих. Часть 3"

Связь многие ко многим

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

Для такой связи нам потребуется создать дополнительную таблицу:

graph_4.png

 

Если мы читаем доку на юбиллинг то видим

-  Да, можно сделать для филиала сколько угодно администраторов, либо передать администратору под управление сколько угодно филиалов.

 

То есть такие связки в базе существуют на уровнях "филиал - администратор" и т.д.

CREATE TABLE `branchesadmins` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `branchid` int(11) NOT NULL,
  `admin` varchar(40) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
CREATE TABLE `branchescities` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `branchid` int(11) NOT NULL,
  `cityid` int(11) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
CREATE TABLE `branchesservices` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `branchid` int(11) NOT NULL,
  `serviceid` int(11) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
CREATE TABLE `branchestariffs` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `branchid` int(11) NOT NULL,
  `tariff` varchar(50) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
CREATE TABLE `branchesusers` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `branchid` int(11) NOT NULL,
  `login` varchar(50) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

Но такой связки я не вижу на уровне  "филиал - филиал".

Наличие двух таких таблиц позволяет создавать не одноуровневую схему "дирекция - филиалы", а масштабируемую, многоуровневую схему  "дирекция - филиалы  - филиалы".

На уровне модулей это позволит получать выборки по фильтрам

- только для себя,

- только для себя и моих филиалов.

и ставить ограничение на просмотр активов с других филиалов.

 

Самый практичный вариант это как написано в уроке "потребуется создать дополнительную таблицу",

на уровне запросов, процедур, и прочей серверной приблуды, это сорвет крышу.

 

Я хочу донести идею, возможно что не так выразился, нет проблем уточню.

 

Відредаговано pavlabor
Ссылка на сообщение
Поделиться на других сайтах

Сорри что выпал из темы ... Итак, в не привязки к юбиллинг :(

Как я решал для себя:

Есть "грубо" 3 таблицы:

"owners" - Владельцы чего либо (будь то директор, филиал, склад или товар/услуга)

Структура простейшая:

{

id  - Идентификатор обьекта

sub - Вышестояший идентификатор 

ver - Версия записи (последнего изменения)

Name - наименование ...

Permission - Символьный набор прав действия ака: "wrade" (Write, Read, Add, Delere, Erase).

                      Притом Delete и Erase - это совсем  разное поведение ...

                      Delete - это присваивание "-1" флаг удалено полю ver, Erase - полное удаление всех записей (only superadmin). ...

}

 

Любые изменения не удаляли/редактировали запись, а создавали дубликат с ver+1 ...

Соответственно в выборках всегда бралась "старшая модель", но с возможностью копнуть в историю ...

 

Далее

Была таблица: Actions.

Грубо - говоря заголовок "расходной накладной", откуда- и куда ...

 

Поля:

{

id

Дата/Время,

Ver (версия как и в предыдущей таблицы)

From (С кого)

To (Кому)

Description (Примечание)

}

 

Ну и напоследок таблица Details ...

{

id,

Action id,,

Ver,

Object_id,

Quantity,

Cost

}

Деталировка что, сколько и за сколько передали ...

 

Суть в чем: перавая таблица -  объекты оперирования, любые ...

Вторая описывает с кого и на что передается (притом не важно что), общий принцип:

Ничто ниоткуда не возникает, и никуда бесследно не пропадает!!!

Нет начальных остатков, нет "переучетов" (в классическом смысле), всё считается на лету ...

Ну и последняя таблица - что конкретно, в каком к-ве и по какой цене передается... 

 

 

Это просто общий набросок который я видел, но скорее всего, не  просто не применимый, ибо сомневаюсь что интегрируется в существующую версия биллинга :(

Посему, я со своей идеей (пасую), в 3 месяца - это не реализовать :(

Відредаговано Stroj
Ссылка на сообщение
Поделиться на других сайтах

Создайте аккаунт или войдите в него для комментирования

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

Создать аккаунт

Зарегистрируйтесь для получения аккаунта. Это просто!

Зарегистрировать аккаунт

Вхід

Уже зарегистрированы? Войдите здесь.

Войти сейчас
  • Зараз на сторінці   0 користувачів

    Немає користувачів, що переглядають цю сторінку.

  • Схожий контент

    • Від ProstoName
      Змінювали мережеву карту. Здається все поправив. Працює. Але є невелика проблема - після внесення коштів (коли абонент був відключений), інет в нього не з'являється. Тільки після заміни тарифу на інший (і потім вернувши тариф) в абонента з'являється інет. 
    • Від felos52357
      Вітаю, колеги!
      Постало питання модернізації вузла (BGP border). На поточному шасі закінчуються вільні слоти, але терміново потрібно підняти ще один широкий аплінк.
      Дивлюся в бік 1-портових інтерфейсних карт (Router Modules 1 Port), щоб зекономити бюджет, бо багатопортові плати зараз коштують космос. Власне, питання до тих, хто експлуатував подібні рішення (Cisco SPA/EPA або Juniper MIC):
      Чи є якісь "підводні камені" у 1-портових модулів в плані черг та буферів? Чи не "обрізані" вони по ASIC ресурсах у порівнянні з повноцінними картами?
      Чи варто займати слот заради одного порта, чи краще одразу шукати плату хоча б на 2-4 порти "на виріст", навіть якщо зараз потрібен лише один?
      Як вони поводяться при повному завантаженні каналу?
      Буду вдячний за реальні відгуки по експлуатації.
    • Від ppv
      Собака-посилака перестала відправляти повідомлення. Підкажіть де шукати.
      Можливо таке після пропадання світла, сервер ребутнувся, але я не впевнений. Візуально все працює, крон працює, а повідомлення висять в черзі, смс така ж картина.

    • Від camchatix
      Привіт!
       
      Є багато запитів, щоб інтернет не виключався у північ, а скажімо в день (сигналізації, камери під охороною і тд)
      При щоденній абонплаті - як знімати гроші не у 12:00 у північ, а наприклад у 11 годин дня ?
    • Від camchatix
      Добрий день,
      створили запасний NAS із зайвою хромосомою, все працює але коли треба вбити сесію користувача - то у списку NAS серверів лише один (той що основний)
      переназначити швидкість теж не можу
      я так розумію пакети CoA Disconnect, CoA connect, PoD - ідуть на IP адресу старого NAS ?
×
×
  • Створити нове...