|
|
|
ключи на разные таблицы вроде [object_id, object_type] - это зло или нет? как лучше?
|
|||
|---|---|---|---|
|
#18+
собственно такой вот вопрос из заголовка нужно ссылаться на 1 из нескольких таблиц, что лучше пара столбцов клю+тип или же отдельные столбцы для каждого? чем плоха связка ключ+тип? может есть какие-то рекомендации как этого избежать вообще? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 19.05.2017, 14:28 |
|
||
|
ключи на разные таблицы вроде [object_id, object_type] - это зло или нет? как лучше?
|
|||
|---|---|---|---|
|
#18+
"Ключ+тип" -- очевидно, никаких (нативных -- триггеры и прочий закат солнца вручную не рассматриваем) гарантий ссылочной целостности. В подавляющем большинстве случаев этого минуса хватает, чтобы такой вариант не использовать. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 19.05.2017, 14:43 |
|
||
|
ключи на разные таблицы вроде [object_id, object_type] - это зло или нет? как лучше?
|
|||
|---|---|---|---|
|
#18+
Ты точно не хотел сказать "нужно ссылаться из одной таблицы на несколько"? А то сейчас звучит так, что ты совсем не понимаешь что такое Foreign Key и как он работает. Posted via ActualForum NNTP Server 1.5 ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 19.05.2017, 14:47 |
|
||
|
ключи на разные таблицы вроде [object_id, object_type] - это зло или нет? как лучше?
|
|||
|---|---|---|---|
|
#18+
авторТы точно не хотел сказать "нужно ссылаться из одной таблицы на несколько"? А то сейчас это конечно, из одной на несколько ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 19.05.2017, 15:49 |
|
||
|
ключи на разные таблицы вроде [object_id, object_type] - это зло или нет? как лучше?
|
|||
|---|---|---|---|
|
#18+
вот думаю если делать отдельные одинаковые таблицы тоже глупо будет выглядеть, хоть технически верно (и удобно) остается только промежуточный вариант - одна таблица с 3 обычными внешними ключами, не красиво только что всегда 2 из 3 будут пустые ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 19.05.2017, 15:53 |
|
||
|
ключи на разные таблицы вроде [object_id, object_type] - это зло или нет? как лучше?
|
|||
|---|---|---|---|
|
#18+
Onaxиз одной на несколько В таком случае эти "несколько" обычно сливаются в одну. Возможно, частично. STFW паттерн "наследование" в применении к реляционной модели. Posted via ActualForum NNTP Server 1.5 ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 19.05.2017, 16:11 |
|
||
|
ключи на разные таблицы вроде [object_id, object_type] - это зло или нет? как лучше?
|
|||
|---|---|---|---|
|
#18+
> всегда 2 из 3 будут пустые Всегда будет только в случае, если ты напишешь check constraint ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 19.05.2017, 17:46 |
|
||
|
ключи на разные таблицы вроде [object_id, object_type] - это зло или нет? как лучше?
|
|||
|---|---|---|---|
|
#18+
Onax это зло или нет? Нет не зло. Но смотреть нужно по месту. Общего правила нет. Иногда делать суррогатный ключ только для того, чтобы сделать ссылку только в нескольких местах неинтересно, проще притащить за собой составной ключ ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 19.05.2017, 20:11 |
|
||
|
ключи на разные таблицы вроде [object_id, object_type] - это зло или нет? как лучше?
|
|||
|---|---|---|---|
|
#18+
Onaxсобственно такой вот вопрос из заголовка нужно ссылаться на 1 из нескольких таблиц, что лучше пара столбцов клю+тип или же отдельные столбцы для каждого? чем плоха связка ключ+тип? может есть какие-то рекомендации как этого избежать вообще? есть, использовать наследование (оно же отношение подкатегории). А то, что предлагаешь ты, это по сути антипаттерн в РБД, так делать нельзя. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 20.05.2017, 09:07 |
|
||
|
ключи на разные таблицы вроде [object_id, object_type] - это зло или нет? как лучше?
|
|||
|---|---|---|---|
|
#18+
Onaxсобственно такой вот вопрос из заголовка нужно ссылаться на 1 из нескольких таблиц, что лучше пара столбцов клю+тип или же отдельные столбцы для каждого? чем плоха связка ключ+тип? может есть какие-то рекомендации как этого избежать вообще? если такое делать по-правильному в РБД, то тебе надо сделать из данной таблицы N необязательных ( nullable) ссылок на другие таблицы, а если нужно будет добавить новую родительскую таблицу, нужно будет вставлять новое поле/набор полей. Чувствуешь, чем пахнет? Это было бы нарушение 1НФ , массив в таблице! ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 20.05.2017, 09:13 |
|
||
|
|

start [/forum/topic.php?fid=32&msg=39456183&tid=1540176]: |
0ms |
get settings: |
9ms |
get forum list: |
14ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
27ms |
get topic data: |
10ms |
get forum data: |
2ms |
get page messages: |
57ms |
get tp. blocked users: |
2ms |
| others: | 13ms |
| total: | 140ms |

| 0 / 0 |

Извините, этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
... ля, ля, ля ...