![]() |
Модераторы: LSD |
![]() ![]() ![]() |
|
qpeHukc |
|
|||
![]() Новичок Профиль Группа: Участник Сообщений: 44 Регистрация: 18.12.2005 Где: Москва Репутация: нет Всего: нет |
Стоит задачаведения статистики действий пользователей в системе вроде форума. Статистика - не просто цифры, а комментарии, даты и цифровая информация.
Пример статистической записи(данные взяты с потолка, чисто для примера) : Пользователь Id=123 Дата заключения контракта : 12-01-2006 Результат : контракт окончен успешно Комментарии сторон : бла бла бла, были счастливы с вами поработать Претензии : мойте руки перед едой ... и т. д. Статистику нужно вести на протяжении всей жизни пользователя в системе. Очевидна (для меня =)) необходимость создания каждому пользователю(пользователь - это организация) своей таблицы. Пользователей - тысячи. Можно конечно вести статистику по месяцам - в таблицу, привязанную к месяцу кидать результаты контрактов всех пользователей. Но тогда как получать статистику по конкретному пользователю ? Получение таких данных будет существенно перегружать систему (проход по всем таблицам статистики для сбора данных по одному пользователю). В связи с этим возник ряд вопросов : Будет ли база данных работать эффективно с огромным колличеством таблиц ? Какие предвидятся траблы(снижение скорости определенных типов запросов и т. д.) ? Поделитесь, пожалуйста опытом, может у кого возникали подобные задачи. |
|||
|
||||
qpeHukc |
|
|||
![]() Новичок Профиль Группа: Участник Сообщений: 44 Регистрация: 18.12.2005 Где: Москва Репутация: нет Всего: нет |
на скуэльру подсказали, что нормально будет писать всю статистику - по всем пользователям в одну таблицу
даже не разделяя по месяцам сомнения... |
|||
|
||||
RatHat |
|
|||
![]() Вождь индейцев ![]() Профиль Группа: Участник Сообщений: 234 Регистрация: 5.9.2005 Репутация: 1 Всего: 1 |
qpeHukc, не вижу смысла под каждого пользователя заводить отдельную таблицу...
просто нормально спроектируй базу, и будет тебе счастье. Статистику по конкретному пользователю добывать запросом. Всё в одну таблицу пихать - тоже некуртуазно. ибо противоречит всем принципам нормализации БД да и в объём этой таблицы будет потом негрустный. --------------------
Ma a kis' hi ve'ist i wan'i na e'ho ho wan'i |
|||
|
||||
Бонифаций |
|
||||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 827 Регистрация: 15.9.2005 Где: Brisbane Репутация: нет Всего: 40 |
а в чем одна таблица в этой задаче нарушает куртуазность, и (что интереснее) принципы нормализации? Вот разбиение на тучу мелких таблиц - да, нарушает. А в одной тблице вся статистика это нормально.
Зависит от базы. Но для баз, хранящих таблицы в каждую в своем файле (postgres, mysql/myisam и тд и тп) - после 5-6 тыщщ таблиц будете гарантировано иметь проблемы с быстродействием. Потому что файловые системы не любят большое количество файлов в одном каталоге. Остальные субд (которые держат все таблицы в одном файле) тоже не слишком любят большое количество таблиц. Доступ к таблицам неоптимизирован. (никому это не надо, таблиц много бывает редко, в основном при неправильном проектировании). Доступ к записям в таблице - оптимизирован многими поколениями разработчиков СУБД. Начиная от банальных индексов, и кончая сложными технологиями типа адаптивного хеширования, partitioning и query-cache. А какое вообще количество записей планируется? -------------------- Бонифаций. |
||||
|
|||||
batigoal |
|
|||
![]() Нелетучий Мыш ![]() ![]() ![]() ![]() Профиль Группа: Участник Клуба Сообщений: 6423 Регистрация: 28.12.2004 Где: Санктъ-Петербургъ Репутация: 1 Всего: 151 |
Идеологически, одна сущность - одна таблица.
-------------------- "Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли) ЖоржЖЖ |
|||
|
||||
qpeHukc |
|
|||
![]() Новичок Профиль Группа: Участник Сообщений: 44 Регистрация: 18.12.2005 Где: Москва Репутация: нет Всего: нет |
ясно, всем спасибо
буду в одной таблице пробовать правда она тогда за год заполнится пару миллионами записей ![]() |
|||
|
||||
Akina |
|
|||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 13 Всего: 454 |
Собсно если грамотно продумать систему индексов и словарей, то миллион-другой записей в год - это ерунда.
-------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
|||
|
||||
LSD |
|
|||
![]() Leprechaun Software Developer ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 15718 Регистрация: 24.3.2004 Где: Dublin Репутация: 24 Всего: 538 |
Таблицу лучше сделать одну, и если надо использовать partitioning.
-------------------- Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it. |
|||
|
||||
batigoal |
|
|||
![]() Нелетучий Мыш ![]() ![]() ![]() ![]() Профиль Группа: Участник Клуба Сообщений: 6423 Регистрация: 28.12.2004 Где: Санктъ-Петербургъ Репутация: 1 Всего: 151 |
Вчера я делал нагрузочный тест, и миллион записей забил за четыре часа. И эта нагрузка считается нормальной. -------------------- "Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли) ЖоржЖЖ |
|||
|
||||
Zamuta |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 389 Регистрация: 18.1.2006 Репутация: нет Всего: 6 |
Если всё писать в одну таблицу, то возникает вопрос - какое максимальное количество столбцов допускает InnoDB и MyIsam таблицы? В мануале не нашёл.
![]() -------------------- Thank you opensource. |
|||
|
||||
Бонифаций |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 827 Регистрация: 15.9.2005 Где: Brisbane Репутация: нет Всего: 40 |
-------------------- Бонифаций. |
|||
|
||||
![]() ![]() ![]() |
Правила форума "Общие вопросы по базам данных" | |
|
Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:
Данный форум не предназначен для:
Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение.
Полезные советы: Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa. |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | СУБД, общие вопросы | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |