Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Организация БД, определение количества таблиц 
:(
    Опции темы
knighter
Дата 10.4.2006, 06:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 5
Регистрация: 10.4.2006

Репутация: нет
Всего: нет



Ситуация:
БД на 10000 пользователей, для кадого пользователя есть некоторый объем информации, которую можно хранить как в
отдельной таблице, там и в виде строки (приходится парсить).

Вопрос такой:
Каким образом лучше организовать структуру БД, с точки зрения быстродействия?
- 10000 таблиц (1 таблица для каждого пользователя);
- 1 таблица для всех пользователей.

PM MAIL   Вверх
boevik
Дата 10.4.2006, 08:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Участник Клуба
Сообщений: 1452
Регистрация: 31.5.2004
Где: Израиль

Репутация: 6
Всего: 35



Если данные однородные, то конечно одна таблица.
10000 записей это и не нагрузка, при нормальных индексах.


--------------------
Никогда не говори никогда
PM MAIL WWW   Вверх
Vit
Дата 10.4.2006, 14:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vitaly Nevzorov
****


Профиль
Группа: Экс. модератор
Сообщений: 10964
Регистрация: 25.3.2002
Где: Chicago

Репутация: 14
Всего: 207



одна таблица


--------------------
With the best wishes, Vit
I have done so much with so little for so long that I am now qualified to do anything with nothing
Самый большой Delphi FAQ на русском языке здесь: www.drkb.ru
PM MAIL WWW ICQ   Вверх
knighter
Дата 11.4.2006, 11:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 5
Регистрация: 10.4.2006

Репутация: нет
Всего: нет



Допустим таблица одна.
Для каждого пользователя нобходимо хранить переменное во времени количество объектов (не одного формата).

Если для каждого объекта создавать запись, то с индексацией будут понты.

Есть вариант для каждого пользователя использовать только одну запись, содер. строку, описывающую объекты пользователя. При добавлении/удалении объекта строка парситься, переформировывается и сохранияется.

Хочу услышать ваше мнение по этому поводу.
PM MAIL   Вверх
Vit
Дата 11.4.2006, 15:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vitaly Nevzorov
****


Профиль
Группа: Экс. модератор
Сообщений: 10964
Регистрация: 25.3.2002
Где: Chicago

Репутация: 14
Всего: 207



Очень трудно понять что именно вы имеете ввиду, но таблица по своей сути должна хранить однородные данные, если предполагается в таблице хранить разнородные данные, значит Вы что-то неправильно спроектировали, а данные должны быть разбиты не по критерию пользователей, а по критерию зависимостей друг от друга и однородности (см. умные книжки по базам данных, раздел "нормализация данных"). Сам по себе критерий "Пользователь" не лучше и не хуже любого другого критерия - рост, цена, имя, объект, свойство или что-то ещё.


--------------------
With the best wishes, Vit
I have done so much with so little for so long that I am now qualified to do anything with nothing
Самый большой Delphi FAQ на русском языке здесь: www.drkb.ru
PM MAIL WWW ICQ   Вверх
nostromo
Дата 14.4.2006, 17:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 194
Регистрация: 23.3.2006

Репутация: нет
Всего: 10



10000 пользователей, насколько я понимаю,
следует понимать как данные, которые сравнительно часто меняются (пользователи добавляются и удаляются).
В случае заведения на каждого пользователя по таблице это приведет к регулярному изменению метаданных (структуры базы данных), а реляционные СУБД этого очень не любят (вспомните, почему нельзя сделать переменную TableName и делать в праметризованные по имени таблицы запросы?).
Этот путь однозначно плохой.

Если не хочется заморачиваться с нормализацией и нужно упростить парсинг, то можно попробовать хранить часть данных в XML формате. Это особенно удобно, когда вы со временем захотите добавлять/удалять/усложнять какие-то поля.
Минус такого подхода -- сложность индексации по инкапсулированным в XML полям.
--------------------
На пыльных тропинках далеких планет останутся наши следы.
PM MAIL   Вверх
THenry
Дата 3.5.2006, 14:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 20
Регистрация: 13.9.2005

Репутация: нет
Всего: нет



1 Таблица + Нормализация до 3НФ  
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0714 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.