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

Какие преимущества&издержки если все id в таблицах guidы? id - "типо

те которые суррогатные первычные ключи по котором затем обычно joinы для "

8 ответов

7 просмотров

Не желательно делать такие ключи кластерными, а без кластерных ключей таблицы в современном SQL server работают хуже. Так что хорошо бы автоинкремент в pk и всё остальное guid

GUID Pros Unique across every table, every database and every server Allows easy merging of records from different databases Allows easy distribution of databases across multiple servers You can generate IDs anywhere, instead of having to roundtrip to the database, unless partial sequentiality is needed (i.e. with newsequentialid()) Most replication scenarios require GUID columns anyway GUID Cons It is a whopping 4 times larger than the traditional 4-byte index value; this can have serious performance and storage implications if you're not careful Cumbersome to debug (where userid='{BAE7DF4-DDF-3RG-5TY3E3RF456AS10}') The generated GUIDs should be partially sequential for best performance (eg, newsequentialid() on SQL Server 2005+) and to enable use of clustered indexes

Работают хуже в чем?

Alexey
Работают хуже в чем?

в работе индексов. Поддержка индексов не очень выгодная. Читать про непоследовательные вставки в кластерный индекс. Вот они происходят и страницы не целиком заполняются , увеличивается фрагментация индекса. Это конечно не страшно по сравнению с мировой революцией, но всё же.

Ilya Zviagin
в работе индексов. Поддержка индексов не очень выг...

Это как раз страшно, если нет регулярного maintenance

Ну, а я о чём?

Ilya Zviagin
Ну, а я о чём?

Ну просто может сложиться ощущение, что прокатит как-нибудь. Не прокатит :)

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

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

а через 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
Карта сайта