Форум Flasher.ru
Ближайшие курсы в Школе RealTime
Список интенсивных курсов: [см.]  
  
Специальные предложения: [см.]  
  
 
Блоги Правила Справка Пользователи Календарь Поиск рулит! Сообщения за день Все разделы прочитаны
 

Вернуться   Форум Flasher.ru > Flash > Серверные технологии и Flash

Версия для печати  Отправить по электронной почте    « Предыдущая тема | Следующая тема »  
Опции темы Опции просмотра
 
Создать новую тему Ответ
Старый 25.02.2014, 04:11
fish_r вне форума Посмотреть профиль Отправить личное сообщение для fish_r Посетить домашнюю страницу fish_r Найти все сообщения от fish_r
  № 1  
Ответить с цитированием
fish_r
 
Аватар для fish_r

блогер
Регистрация: Jan 2011
Сообщений: 1,162
Записей в блоге: 4
По умолчанию По разработке структуры БД

Дано, в БД есть таблица, например Пользователи, есть другая, например какие то Акты совершенные этими пользователями. Будет возникать потребность суммировать кол-во актов в отношении кого либо из пользователей. Вариантов решений два:
1. Сделать поле для пользователя где вести учет кол-ва актов.
2. Каждый раз когда понадобится делать выборку в таблице актов, в отношении пользователя.

Сразу, чтобы не рубили с плеча, поясню в чем проблема. Если вводить подобные поля, согласно пп 1 то это значит сильно увеличивать риск ошибок связанный с тем, что при любой реорганизации модели обмена надо помнить, что необходимо обновлять значения таких полей, упустишь один раз и можно получить серьезные перекосы в результатах... Вроде бы решение 2 лучше, ведь бд просто заточены под решение задач по выборке, но.... блин, это же такая работа каждый раз! Какое же решение предпочесть??

ПС. Здесь ситуация примерная и сильно упрощенная, в реале все конечно немного сложнее ( больше таблиц и подобных полей и тд. ), упростил чтобы яснее очертить проблему

Старый 25.02.2014, 08:47
alexcon314 вне форума Посмотреть профиль Отправить личное сообщение для alexcon314 Найти все сообщения от alexcon314
  № 2  
Ответить с цитированием
alexcon314
listener

модератор форума
Регистрация: Jun 2006
Сообщений: 3,260
Записей в блоге: 28
Отправить сообщение для alexcon314 с помощью ICQ
Первый вариант очень скользкий, выгоды очень сомнительны, потом поле с учетом актов само по себе избыточно по логике. Ну, т.е. это не юзерская информация в том смысле, что нарушает инкапсуляцию: нафига пользователю знать что он там наделал? Он просто солдат....На худой конец, можно какой-нибудь триггер замутить, если уж очень хочется иметь сумму сразу под рукой.
Лучше оптимизируй второй вариант: индексы, ключи, процедуры хранимые.
Еще такой ход: в отдельной таблице с двума столбцами хранить соответствие user_id <-> job_id. Тут можно избавиться от дублирования записей в актах, когда он выполнен несколькими пользователями, к примеру.

Старый 25.02.2014, 09:11
bifidokk вне форума Посмотреть профиль Отправить личное сообщение для bifidokk Найти все сообщения от bifidokk
  № 3  
Ответить с цитированием
bifidokk
 
Аватар для bifidokk

Регистрация: Jan 2011
Сообщений: 200
Уже написал вам в чатике. Почитайте про денормализацию БД. Если количество подобных актов будет исчисляться миллионами, то легче завести счетчик в таблице Пользователи, чем постоянно делать выборку.

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

Старый 25.02.2014, 09:26
Korchy вне форума Посмотреть профиль Отправить личное сообщение для Korchy Найти все сообщения от Korchy
  № 4  
Ответить с цитированием
Korchy
 
Аватар для Korchy

Регистрация: May 2011
Сообщений: 301
Записей в блоге: 2
Возможно вам помогут "представления". Это тот же запрос, но уже со сделанной выборкой в виде итоговой таблицы. Выборка переделывается только при изменении данных в исходных таблицах, так что для каждого просмотра выборка перепроизводиться не будет.
__________________
interplanety

Старый 25.02.2014, 10:04
fish_r вне форума Посмотреть профиль Отправить личное сообщение для fish_r Посетить домашнюю страницу fish_r Найти все сообщения от fish_r
  № 5  
Ответить с цитированием
fish_r
 
Аватар для fish_r

блогер
Регистрация: Jan 2011
Сообщений: 1,162
Записей в блоге: 4
Спасибо за советы! Про "представления" очень интересно, покавыряю тему. Про денормализацию... , пока не предпологается что записей будет несколько миллионов, а если уже будет тогда решать надо будет привлечением спеца серверника и/или спеца по бд, в общем уже на другом уровне надо будет решать...

Старый 25.02.2014, 12:39
Psycho Tiger вне форума Посмотреть профиль Отправить личное сообщение для Psycho Tiger Найти все сообщения от Psycho Tiger
  № 6  
Ответить с цитированием
Psycho Tiger
 
Аватар для Psycho Tiger

блогер
Регистрация: Jun 2005
Адрес: Господи пожалуйста не Новосибирск
Сообщений: 6,598
Записей в блоге: 17
А данные нужно обновлять оперативно? Как насчет кэширования в редисе на часик для одного пользователя?

Старый 25.02.2014, 15:34
fish_r вне форума Посмотреть профиль Отправить личное сообщение для fish_r Посетить домашнюю страницу fish_r Найти все сообщения от fish_r
  № 7  
Ответить с цитированием
fish_r
 
Аватар для fish_r

блогер
Регистрация: Jan 2011
Сообщений: 1,162
Записей в блоге: 4
Почитал поверхностно про редисы/мемкешид и т.п. Очень интересно, но пока о таких решениях рано задумываться ( насколько я понял это для нагруженных систем ), но за инфу спасибо! Буду иметь в виду.

Старый 25.02.2014, 16:49
Psycho Tiger вне форума Посмотреть профиль Отправить личное сообщение для Psycho Tiger Найти все сообщения от Psycho Tiger
  № 8  
Ответить с цитированием
Psycho Tiger
 
Аватар для Psycho Tiger

блогер
Регистрация: Jun 2005
Адрес: Господи пожалуйста не Новосибирск
Сообщений: 6,598
Записей в блоге: 17
Вобщем-то да.
Но непонятно – если твоя система не планируется в эксплуатации под хайлоадом – пусть себе БД делает кучу джоинов и считает каждый раз заново – ей всё равно скучать бОльшую часть времени.

Создать новую тему Ответ Часовой пояс GMT +4, время: 07:37.
Быстрый переход
  « Предыдущая тема | Следующая тема »  
Опции темы
Опции просмотра

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.


 


Часовой пояс GMT +4, время: 07:37.


Copyright © 1999-2008 Flasher.ru. All rights reserved.
Работает на vBulletin®. Copyright ©2000 - 2024, Jelsoft Enterprises Ltd. Перевод: zCarot
Администрация сайта не несёт ответственности за любую предоставленную посетителями информацию. Подробнее см. Правила.