172 похожих чатов

Есть вопрос небольшой. Допустим есть таблица для хранения данных о пользователе,

но там к примеру может быть 10 или 15 полей (там id, name, city, username, birth... и т.д). Это нормальная практика делать столько столбцов в таблице, или это лучше как-то разделить допустим на 2 таблицы?

10 ответов

17 просмотров

select count(*) from pg_attribute where attrelid = 1264048910 and attnum > 0 and not attisdropped; count ------- 123 (1 строка)

Стас- Автор вопроса
Iurii Shaporenko
select count(*) from pg_attribute where attrelid =...

Значит да, может быть много полей и ничего страшного?

ну вот все что не меняется по пользователю можно и в одну таблицу. но на практике человек даже им может сменить.

Разделять просто потому что гораздо хуже чем много столбцов в таблице

Число колонок не так страшно, сколько страшен общий размер строки. Желательно чтобы он был до 2кбайт.

Ildar Garaev
ну вот все что не меняется по пользователю можно и...

> ну вот все что не меняется по пользователю можно и в одну таблицу Только если есть требование хранения истории изменений каких-то атрибутов. А так всему, что относится к пользователю, место в таблице пользователей.

Это "всего лишь" теоретически неправильное моделирование, притом без каких-либо адекватных причин, just FYI. Т.е. чем наличие 15 полей хуже, чем 2 (5, 15...) таблиц?

Yaroslav Schekin
Это "всего лишь" теоретически неправильное моделир...

Накладные расходы на их соединение, повышенная сложность, повышения вероятность ошибок

central hardware
Накладные расходы на их соединение, повышенная сло...

Это Вы написали или нет? > Разделять просто потому что гораздо хуже чем много столбцов в таблице И теперь сами же против этого возражаете? ;)

Похожие вопросы

Обсуждают сегодня

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Ребят в СИ можно реализовать ООП?
Николай
33
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
у вас два процесса. один посылает другому сигнал. у вас есть код обоих процессов? если всё не так - расскажите как оно на самом деле. а именно кто кому чего, есть-ли консоли,...
Karagy
6
Карта сайта