Текущий архив: 2008.02.03;
Скачать: CL | DM;
ВнизК вопросу о культурном проектировании реляционных БД Найти похожие ветки
← →
Kostafey © (2007-12-22 14:57) [0]Работать-то оно может по-всякому, но абы-как почему-то больше не хочется.
Если это имеет в данном случае значение, использую MS SQL Server 2005.
Возникают у меня такие вопросы:
1)Каков должен быть регистр символов в названии таблиц, полей ?
2)Является ли нежелательным использование занака _ в названии таблиц, полей ?
3)Как лучше всего называть поля-иденитификаторы и внешние ключи
4)Критично ли использование излишних связей, например
есть таблицы Страна, Субъект(связанный со Страной), Город(связвнный с Субъектом),
так мы Город еще и к Стране привязываем
5)Допускается ли использовать 1 поле для хранения данных разных с точки
зрения модели БД.
Например есть следующая структура:
таблица Материалы_на_складе, поля:
Id_склада
Алюминий
Чугуний
Бетоний
Деревяний
заменяем на:
Таблица Материалы_на_складе, поля:
Id_склада
Вид_вещетсва
Количество
Таблица Вид_вещетсва, поля:
id_вида
Вид
Сответственно, 1 склад уже будут характеризовать несколько записей
6)Допускается ли исползовать одно и тоже поле в качестве внешнего
ключа к нескольким таблицам (информация к какой именно таблице является
внешним ключ в данной записи находиться в другом поле)
Буду очень признателен за любые советы.
← →
Petr V. Abramov © (2007-12-22 15:44) [1]1. согласно внутреннему стандарту
2. см. 1.
3. осмысленно
4. некритично, но нежелательно без веских оснований, как и любая денормализация
5.
> заменяем на:
именно так и делаем.
потму что как только появятся стекляний и оловяний, структура базы и куча кода полетит к чертям. Если кто-то от заказчика утверждает, что стекляний и оловяний не появятся никогда, покивай, но не верь.
6. Допускается, но лучше не допускать.
← →
Kostafey © (2007-12-22 15:52) [2]> [1] Petr V. Abramov © (22.12.07 15:44)
> 1. согласно внутреннему стандарту
> 2. см. 1.
Я и есть этот стандарт :)
> 3. осмысленно
Ну вот например, для приведенной в п.5 структуры:
Sklad
Id
Id_VidVeshestva
Kol
VidVeshestva
Id
Vid
Нормально?
> 5.
>
> > заменяем на:
>
> именно так и делаем.
> потму что как только появятся стекляний и оловяний, структура
> базы и куча кода полетит к чертям. Если кто-то от заказчика
> утверждает, что стекляний и оловяний не появятся никогда,
> покивай, но не верь.
>
> 6. Допускается, но лучше не допускать.
Понял, спасибо.
← →
Petr V. Abramov © (2007-12-22 15:57) [3]> Kostafey © (22.12.07 15:52) [2]
я по-английски называю, кому-то больше транслитерацией нравится.
тут холивар большой был на эту тему.
← →
Petr V. Abramov © (2007-12-22 15:58) [4]если называть по английски, ни у кого не возникнет подозрения, что проектировал первокурсник :)
← →
kaif © (2007-12-22 16:04) [5]4. Либо устраняем поле Город в Субъекте, либо делаем внешний ключ сразу на два поля (Субъект.Город, Страна -> Город, Страна). Для этого Таблица Город должна иметь альтернативный уникальный ключ Город, Страна. Не знаю, позволяет ли MS SQL задавать внешние ключи на группу полей - IB позволяет. Я бы все же устранил поле Страна в Субъекте.
5. Однозначно требует нормализации.
6. Неужели MS SQL такое позволяет декларативно объявлять? Я бы так не стал делать, если честно. Уж лучше создать некий "журнал", в котором дублировать элементы из разных таблиц и на него ссылаться.
В общем, все что касается стандарта (регистр букв, названия полей) - дело вкуса и здесь важнее единообразие. А что касатся нормализации - лучше все изначально нормализовать по максимуму, а потом что-то с умом денормализовать.
← →
Kostafey © (2007-12-22 16:05) [6]> [3] Petr V. Abramov © (22.12.07 15:57)
> > Kostafey © (22.12.07 15:52) [2]
> я по-английски называю, кому-то больше транслитерацией нравится.
> тут холивар большой был на эту тему.
Как же я пропустил его :)
Ссылочки не сохранилось?
> [4] Petr V. Abramov © (22.12.07 15:58)
> если называть по английски, ни у кого не возникнет подозрения,
> что проектировал первокурсник :)
Это почему?
Я вообще видел вперемешку написано.
← →
Petr V. Abramov © (2007-12-22 16:07) [7]> Kostafey © (22.12.07 16:05) [6]
> Я вообще видел вперемешку написано
говорит об отсутствии стандартов
← →
kaif © (2007-12-22 16:15) [8]Правильно писать Id_VidVeschestva
:))
← →
Kostafey © (2007-12-22 16:16) [9]> [7] Petr V. Abramov © (22.12.07 16:07)
> > Kostafey © (22.12.07 16:05) [6]
> > Я вообще видел вперемешку написано
> говорит об отсутствии стандартов
Вот и хочу я его ввести.
Но из пальца высасывать - одно, сходить за советом - другое.
> [5] kaif © (22.12.07 16:04)
> 4. Либо устраняем поле Город в Субъекте,
Так и нет его.
Структура такова:
Страна:
ИД
Название
Субъект:
ИД
ИД_Страны
Название
Город:
ИД
ИД_Субъекта
ИД_Страны
Название
> 5. Однозначно требует нормализации.
Угу, понял.
> 6. Неужели MS SQL такое позволяет декларативно объявлять?
Ну вот товарищ умудрился.
> Уж лучше создать некий "журнал", в котором дублировать элементы
> из разных таблиц и на него ссылаться.
Это как?
> В общем, все что касается стандарта (регистр букв, названия
> полей) - дело вкуса и здесь важнее единообразие. А что касатся
> нормализации - лучше все изначально нормализовать по максимуму,
> а потом что-то с умом денормализовать.
Согласен. Спасибо.
← →
Kostafey © (2007-12-22 16:18) [10]> [8] kaif © (22.12.07 16:15)
> Правильно писать Id_VidVeschestva
> :))
Да, у меня где-то валялась таблица транслита :)
← →
Petr V. Abramov © (2007-12-22 16:30) [11]я так думаю 6. напрямую растет из 5.
← →
Kostafey © (2007-12-22 16:33) [12]> [11] Petr V. Abramov © (22.12.07 16:30)
> я так думаю 6. напрямую растет из 5.
Не совсем понял. Это как?
← →
kaif © (2007-12-22 16:34) [13]> Уж лучше создать некий "журнал", в котором дублировать элементы
> из разных таблиц и на него ссылаться.
Это как?
Допустим у Вас имеется 4 таблицы: счета выставленые, счета полученные, накладные исходящие, накладные входящие. И еще могу появиться новые таблицы со своеобразными полями.
А Вы хотите иметь общую подчиненную таблицу позиций с одинаковой структурой для всех подобных документов. Содержащую поля: товар, кол-во, цена без НДС, НДС.
Тогда можно сделать общий "журнал", в который переписывать строки из тех 4 таблиц в каком-то сокращенном виде, например в виде ID, тип документа, дата, сумма, а на него ссылаться из талицы позиций.
← →
Kostafey © (2007-12-22 16:41) [14]> [13] kaif © (22.12.07 16:34)
> > Уж лучше создать некий "журнал", в котором дублировать
> элементы
> > из разных таблиц и на него ссылаться.
>
> Это как?
Понял, но требуется не сокращенная, а полная информация.
Как вариант решения:
Сделать в общей подчиненной таблице поля-внешние ключи ко
всем таблицам Счетов, и отдельно поле для того, чтобы
характеризовать к какой именно таблице счетов
следует обращаться в текущей записи.
← →
kaif © (2007-12-22 16:42) [15]Это позволит сделать более изящную навигацию и фильтрацию документов, не прибегая к конструкциям типа UNION.
В принципе подобные "журналы" и есть некоторый безопасный способ денормализации.
Сначала мы все строго разбиваем на отдельные сущности, а потом строим журналы, в которых эти сущности объединяем по наиболее общим полям.
Злоупотреблять этим не стоит, но иногда выигрыш может быть невероятным.
Представьте себе 50 таблиц типизированных товаров с их особенными полями и общий журнал - таблицу, в которую сведены просто их ID и наименование. В таких случаях удобно иметь сквозной уникальный ID на все товары. В IB для этого удобно использовать генераторы. В MS SQL не знаю. ГУИДы какие-нибудь страшные, возможно, сойдут :)
← →
kaif © (2007-12-22 16:43) [16]Kostafey © (22.12.07 16:41) [14]
Сделать в общей подчиненной таблице поля-внешние ключи ко
всем таблицам Счетов, и отдельно поле для того, чтобы
характеризовать к какой именно таблице счетов
следует обращаться в текущей записи.
Я не представляю, как такое можно объявитьв MS SQL.
И еще меньше я себе представляю, как потом делать SQL-запросы, например, как запросить все "позиции", объединенные с их "шапками".
← →
Sergey Masloff (2007-12-22 16:52) [17]1-4 к проектированию отношения не имеют.
5 Так и нужно в большинстве случаев
6 Если нельзя но очень хочется (и можешь обосновать почему хочется) то можно
← →
Kostafey © (2007-12-22 16:56) [18]
> [16] kaif © (22.12.07 16:43)
Я не представляю, как такое можно объявитьв MS SQL.
Склад
Ид_бетония
Ид_чугуния
Нужный_Ид //1-бетоний, 2-чугуний
Бетоний
ИД
прочие_поля
Чугуний
ИД
прочие_поля
пример содержимое таблицы Склад:
ИД | Ид_бетония | Ид_чугуния | Нужный_Ид
0 | 34 | null | 1
1 | 45 | null | 1
2 | null | 13 | 2
3 | null | 89 | 2
> И еще меньше я себе представляю, как потом делать SQL-запросы,
> например, как запросить все "позиции", объединенные с их
> "шапками".SELECT *
FROM Склад
JOIN Бетоний on (Бетоний.ИД = Склад.Ид_бетония)
WHERE Склад.Нужный_Ид = 1
UNION
SELECT *
FROM Склад
JOIN Чугуний on (Чугуний.ИД = Склад.Ид_чугуния)
WHERE Склад.Нужный_Ид = 2
← →
Kostafey © (2007-12-22 17:01) [19]> [17] Sergey Masloff (22.12.07 16:52)
> 1-4 к проектированию отношения не имеют.
Согласен, я просто думал есть какой-то аналог
Code Conventions :)
> 5 Так и нужно в большинстве случаев
Уяснил.
> 6 Если нельзя но очень хочется (и можешь обосновать почему
> хочется) то можно
Хорошо, ну а как вообще тогда реализовывать обсуждаемое в
> [14] Kostafey © (22.12.07 16:41)
← →
Sergey Masloff (2007-12-22 17:17) [20]Kostafey © (22.12.07 17:01) [19]
А я не понял что обсуждается. Типа "наследования"? Когда в двух таблицах с разными сущностями много похожих полей? Типа "юр.лица" и "физ. лица" но все они "клиенты"? Можно в одну таблицу вынести все общее. Тебя беспокоит что поле ID в этой таблице в зависимости от типа клиента будет ключем на таблицу - "расширение"?
Я бы сделал главной таблицей "клиенты" под ней 1:1 "таблицы расширений"
Поставил бы защиту от редактирования на "главную" а при записи в "детальные" заполнял бы и "главную". Как один из вариантов, на самом деле имеющих право на жизнь вариантов много
← →
Johnmen © (2007-12-22 17:19) [21]Допустимо всё, что напрямую не запрещено теорией.
Применяем правила нормализации, но имеем право от них отступать, если это даст эффект в скорости, объеме и т.п.
Всё остальное неспешный трёп :)
Если есть конкретный вопрос, то именно его и следует обсасывать...
← →
Sergey Masloff (2007-12-22 17:20) [22]Johnmen © (22.12.07 17:19) [21]
>Допустимо всё, что напрямую не запрещено теорией.
Я бы расширил: даже то что запрещено теорией можно иногда нарушать (если есть уверенность в своей правоте и возможность проверить)
← →
Johnmen © (2007-12-22 17:23) [23]
> Sergey Masloff (22.12.07 17:20) [22]
Да, пожалуй.
← →
kaif © (2007-12-22 17:26) [24]В общем, нарушение правил нормализации, как и правил дорожного движения, должно быть осознанным и точно рассчитанным. Иначе неминуемы ДТП.
← →
Kostafey © (2007-12-22 17:48) [25]> [20] Sergey Masloff (22.12.07 17:17)
> Kostafey © (22.12.07 17:01) [19]
> А я не понял что обсуждается. Типа "наследования"? Когда
> в двух таблицах с разными сущностями много похожих полей?
> Типа "юр.лица" и "физ. лица" но все они "клиенты"? Можно
> в одну таблицу вынести все общее. Тебя беспокоит что поле
> ID в этой таблице в зависимости от типа клиента будет ключем
> на таблицу - "расширение"?
Отличный пример. В [18] Kostafey © (22.12.07 16:56)
я хотел лишь продемонстрировать механизм, но никак не
сущность.
> Я бы сделал главной таблицей "клиенты" под ней 1:1 "таблицы
> расширений"
Т.е. все-таки "1 поле связи на все детальные", вместо
"на каждую детальную - свое поле как в [18]"
> Поставил бы защиту от редактирования на "главную" а при
> записи в "детальные" заполнял бы и "главную". Как один из
> вариантов, на самом деле имеющих право на жизнь вариантов
> много
Не совсем понял. Т.е. редактирование таблиц
осущствляем только вместе: голавная + детальная?
Ну так программно оно так и реализуется.
Или имеется в виду реализовать в самой БД?
← →
MsGuns © (2007-12-22 19:51) [26]Советую прежде чем приступать к проектированию таблиц (полей таблиц, межтабличных связей и т.д.) "нарисовать" объектную модель предмета автоматизации, в которой каждую конечную сущность ("Страна", "Склад", "Материал", "Документ" и т.д.) представить объектом с характеристиками (свойствами), адекватно описывающими этот объект.
Затем свойства всех объектов поместить в сводную таблицу характеристик, по которой уже можно приступать к номрмализации.
Создание таблиц вместе с полями выполнять только после того, как "прояснится на доске", то бишь на сводной таблице
← →
tesseract © (2007-12-22 21:43) [27]
> Советую прежде чем приступать к проектированию таблиц (полей
> таблиц, межтабличных связей и т.д.) "нарисовать" объектную
> модель предмета автоматизации, в которой каждую конечную
> сущность ("Страна", "Склад", "Материал", "Документ" и т.
> д.)
UML-ом попахивает. На самом деле после 2-3 лет работы автоматически проектируешь. Как привык на данной платформе. Но сущности это все фигня, вот когда сводные таблицы движений/остатков начинаешь делать, вот тут трижды подумаешь какую избыточность вносить.
> А я не понял что обсуждается. Типа "наследования"? Когда
> в двух таблицах с разными сущностями много похожих полей?
> Типа "юр.лица" и "физ. лица" но все они "клиенты"? Можно
> в одну таблицу вынести все общее.
Это уже объектно-реляцоныые базы называеться. Постгресс, cache, Oracle умеют с такими данными работать. Очень кстати удобно при рефакторинге базы - код можно не трогать.
← →
MsGuns © (2007-12-22 21:50) [28]>tesseract © (22.12.07 21:43) [27]
>UML-ом попахивает. На самом деле после 2-3 лет работы автоматически проектируешь.
Есть такие предметные области, что и 20 лет опыта не хватает, чтобы "автоматически проектировать"
← →
Anatoly Podgoretsky © (2007-12-22 21:53) [29]
> Kostafey © (22.12.07 15:52) [2]
> > [1] Petr V. Abramov © (22.12.07 15:44)
> > 1. согласно внутреннему стандарту
> > 2. см. 1.
>
> Я и есть этот стандарт :)
Много на себя ведешь, СУБД имеет возможность дать тебе по ушам
← →
Loginov Dmitry © (2007-12-22 23:54) [30]> 1)Каков должен быть регистр символов в названии таблиц,
> полей ?
От самой базы зависит. В InterBase принято все поля вводить заглавными буквами. В табличках DBF - также. В Paradox - прописные и строчные буквы чередуются. Лучше просто смотреть поставляемые с СУБД примеры и придерживаться того же стиля.
> 2)Является ли нежелательным использование занака _ в названии
> таблиц, полей ?
В InterBase данный символ - стандарт. В Paradox - практически не применяется. Насчет MS SQL Server - не знаю. Рекомендация та же, что и в предыдущем пункте.
> 3)Как лучше всего называть поля-иденитификаторы и внешние
> ключи
Прежде всего имя любого поля лучше всего начинать с префикса - 2-3 символа, являющиеся сокращением имени таблицы. Этому правилу поддаются и поля-идентификаторы. При этом придумывать имена внешних ключей нет необходимости - они уже известны, т.к. являются первичными ключами связанных таблиц.
> 4)Критично ли использование излишних связей, например
> есть таблицы Страна, Субъект(связанный со Страной), Город(связвнный
> с Субъектом),
> так мы Город еще и к Стране привязываем
Все правильно! Их следует связывать, причем именно в таком порядке!
> 5)Допускается ли использовать 1 поле для хранения данных
> разных с точки
> зрения модели БД.
> Например есть следующая структура:
> таблица Материалы_на_складе, поля:
> Id_склада
> Алюминий
> Чугуний
> Бетоний
> Деревяний
Если набор материалов фиксированный, то ради бога! Можно и так! Но чаще всего каждый материал обладает каким-то набором дополнительных свойств. К тому же номенклатура материалов может расширяться! Тогда данная схема становится неудобной.
> заменяем на:
>
> Таблица Материалы_на_складе, поля:
> Id_склада
> Вид_вещетсва
> Количество
>
> Таблица Вид_вещетсва, поля:
> id_вида
> Вид
> Сответственно, 1 склад уже будут характеризовать несколько
> записей
Это более гибкий подход!
> 6)Допускается ли исползовать одно и тоже поле в качестве
> внешнего
> ключа к нескольким таблицам (информация к какой именно таблице
> является
> внешним ключ в данной записи находиться в другом поле)
Ну это уже какое-то извращение!
← →
Loginov Dmitry © (2007-12-22 23:59) [31]> Так и нет его.
> Структура такова:
> Страна:
> ИД
> Название
> Субъект:
> ИД
> ИД_Страны
> Название
> Город:
> ИД
> ИД_Субъекта
> ИД_Страны - это здесь совершенно ненужно, т.к. субъект однозначно определяет страну!
> Название
← →
Petr V. Abramov © (2007-12-23 02:45) [32]> tesseract © (22.12.07 21:43) [27]
Oracle умеют с такими данными работать. Очень кстати удобно при рефакторинге базы - код можно не трогать.
и Oracle это не умеет, и код надо трогать :)
11-й Oracle пока не трогал :)
← →
Kostafey © (2007-12-23 14:11) [33]> [26] MsGuns © (22.12.07 19:51)
Вот все это, конечно хорошо, минус в том, что есть некая
преемственность от старых решений.
БД уже была реализована в Access и эксплуатировалась,
проектировалоса она - абы работало.
Я за то чтоыб проектировать с 0, но заказчик ничего
другого как модифицировать уже сделанную в Access БД
и знать не хочет.
> [29] Anatoly Podgoretsky © (22.12.07 21:53)
> > Я и есть этот стандарт :)
>
> Много на себя ведешь, СУБД имеет возможность дать тебе по
> ушам
MS SQL Server точно не даст: хоть по-русски поля называй, не даст.
> [30] Loginov Dmitry © (22.12.07 23:54)
> Прежде всего имя любого поля лучше всего начинать с префикса
> - 2-3 символа, являющиеся сокращением имени таблицы. Этому
> правилу поддаются и поля-идентификаторы. При этом придумывать
> имена внешних ключей нет необходимости - они уже известны,
> т.к. являются первичными ключами связанных таблиц.
Раньше я так и делал. При небольшом количестве таблиц - очень удобно:
Gruppa:
G_id
G_name
Student:
S_id
S_FIO
S_G_id //В какой группе студент
Select *
Form Student, Gruppa
Where S_G_id=G_id
Но когда таблиц много, я думаю лучше пользоваться
полным именем поля, т.е.:
Gruppa:
id
name
Student:
id
FIO
Gruppa_id //В какой группе студент
Select *
Form Student, Gruppa
Where Student.Gruppa_id=Gruppa.id
← →
Anatoly Podgoretsky © (2007-12-23 22:50) [34]
> MS SQL Server точно не даст: хоть по-русски поля называй,
> не даст.
Даст, поскольку и там можно сделать чувствительность к регистру.
> 1)Каков должен быть регистр символов в названии таблиц,
> полей ?
← →
Бакук © (2007-12-24 05:11) [35]> Раньше я так и делал. При небольшом количестве таблиц —
> очень удобно:
> Gruppa:
> G_id
> G_name
> Student:
> S_id
> S_FIO
> S_G_id //В какой группе студент
>
> Select *
> Form Student, Gruppa
> Where S_G_id=G_id
Появляется еще одна таблица, название которой начинается на G и через некоторое время возникнет небольшая путаница, что же такое G_id (к какой именно таблице оно относится).
Я обычно делаю так. Поле «Код» в любой таблице всегда называется ID, а ссылки на другие таблицы маркируются как ID_ИмяТаблицы: ID_GROUP, ID_STUDENT etc.
> > 6)Допускается ли исползовать одно и тоже поле в качестве
>
> > внешнего
> > ключа к нескольким таблицам (информация к какой именно
> таблице
> > является
> > внешним ключ в данной записи находиться в другом поле)
А приведите пример, чтобы необходимо было использовать такой подход?
> 2)Является ли нежелательным использование занака _ в названии таблиц, полей ?
Я часто использую нижнее подчеркивание. Как здесь говорили, очень удобно таблицы группировать с помощью префикса. Например, AGR_, STR_, FIN_, CMT_
Да и если таблица называется замудренно, легче читать с подчеркиванием (из увиденного недавно: CLIENTSGROUPSRELATIONS, мне удобнее прочесть CLIENTS_GROUPS_RELATIONS, хотя конечно название изначально неудачное, уж слишком много букв :)
← →
ZeroDivide © (2007-12-24 09:31) [36]
> 1)Каков должен быть регистр символов в названии таблиц,
> полей ?
>
> 2)Является ли нежелательным использование занака _ в названии
> таблиц, полей ?
>
> 3)Как лучше всего называть поля-иденитификаторы и внешние
> ключи
Главное все это называть однообразно. Т.е. в соответствии с каким-нибудь стандартом, пусть даже собственным, внутренним.
← →
Anatoly Podgoretsky © (2007-12-24 11:14) [37]
> Раньше я так и делал.
Еще одна жертва венгерской нотации и работа с Паскалем не помогла.
← →
tesseract © (2007-12-24 11:56) [38]
> и Oracle это не умеет, и код надо трогать :)11-й Oracle
> пока не трогал :)
Вроде заявляли, что наследование поддерживаеться. Слоник умеет. Имееться в виду заводишь например документ отнаследованный от другого, добавляешь ему поле и переписываешь только код для этого документа.
← →
Petr V. Abramov © (2007-12-24 12:08) [39]> tesseract © (24.12.07 11:56) [38]
поддерживается, даже работает без особых глюков.
только на "добавленное поле" foreign key нельзя поставить, по крайней мере, у меня не получилось.
Синтаксические возможности есть, но не создается, выдает идиотские ошибки.
Поэтому ценность приближается к нулю
← →
Kostafey © (2007-12-24 14:25) [40]> [35] Бакук © (24.12.07 05:11)
> А приведите пример, чтобы необходимо было использовать такой
> подход?
[20] Sergey Masloff (22.12.07 17:17)
очень хороший пример привел.
Со всем остальным согласен на 100%
> [37] Anatoly Podgoretsky © (24.12.07 11:14)
> > Раньше я так и делал.
> Еще одна жертва венгерской нотации и работа с Паскалем не
> помогла.
Каюсь, ибо я грешен, :)
теперь делаю по-другому
см. [33] Kostafey © :
> Но когда таблиц много, я думаю лучше пользоваться
> полным именем поля, т.е.:
>
> Gruppa:
> id
> name
> Student:
> id
> FIO
> Gruppa_id //В какой группе студент
>
> Select *
> Form Student, Gruppa
> Where Student.Gruppa_id=Gruppa.id
← →
MOA © (2007-12-24 23:48) [41]Моё СМ - любое нарушение нормализации приводит в итоге - не, не сразу, конечно - лет так через 3 - к огромной величины гемморою.
Сам был грешен, тоже думал "зато работать будет быстрее". Нет. Не быстрее. Селективность индексов по "классовым" полям как правило, никакая, оптимизатор скорее предпочтёт перебор (утрирую) чем такой "индекс", но геморрой с будущими запросами - ужасный. Самое печальное - что быстрее-то не получается, через 2-3 года тот кажущийся "прирост производительности" будет уже ничтожен - а то и отрицательный.
← →
Kostafey © (2007-12-26 00:59) [42]> [41] MOA © (24.12.07 23:48)
Спасибо, очень полезная информация.
← →
Sergey13 © (2007-12-26 10:10) [43]> [41] MOA © (24.12.07 23:48)
Это лечится правильным тестированием системы. Можно нагенерировать данных на 5-10 лет и смотреть производительность на "реальных" объемах. Полностью нормализованные базы могут тормозить не менее (а то и более) денормализованных. Другое дело, что денормализация обычно делается за счет избыточности информации, а это в свою очередь порождает проблему ее целостности, за которой надо следить.
ИМХО истина всегда где-то посередине.
К тому же борьба за производительность не заканчивается с написанием системы. Это постоянная работа на все время жизни продукта.
Страницы: 1 2 вся ветка
Текущий архив: 2008.02.03;
Скачать: CL | DM;
Память: 0.61 MB
Время: 0.066 c