При использовании стратегии генерации идентификатора HiLo, какие типы должны использоваться для хранения идентификаторов? - PullRequest
2 голосов
/ 10 мая 2010

Я спрашиваю это с точки зрения c # / NHibnernate, но в целом это применимо. Проблема заключается в том, что стратегия HiLo работает, хотя идентификаторы работают довольно быстро, и, например, таблица с небольшим количеством записей (например, «Пользователи») делится из того же набора идентификаторов, что и таблица с большим количеством записей (например, комментарии). Таким образом, вы можете получить большие цифры быстрее, чем с другими стратегиями. Так что люди рекомендуют?

Сторона кода: INT / UINT / длинный / ULONG?

DBSide: INT / BIGINT?

У меня такое чувство, что я должен идти с длинным и бигингтом, но хотел бы проверить здравомыслие :) 1007 *

Ответы [ 2 ]

5 голосов
/ 12 мая 2010

Дополняет ответ Диего ..

Вы можете установить параметр table для каждого генератора, но IMO приводит к ненужному количеству таблиц только для хранения идентификаторов.

Я бы, вероятно, рекомендовал использовать одну строку для каждой сущности (в той же таблице). С дополнительными параметрами вы можете настроить алгоритм HiLo, и он будет блокировать только необходимую строку. У вас есть разные семена для каждой сущности. В FluentNH это было бы что-то похожее на:

        Id(x => x.Id, "Id")
            .GeneratedBy.HiLo("IdsTable", "id", "20", 
                p => p.AddParam("where", "table = 'mappedent'"));

Несмотря на это, вы также можете обойтись без дополнительного параметра where и просто установить другой столбец (что позволяет иметь разные типы идентификаторов даже в БД). Тем не менее, это будет беспокоить вас, если у вас есть большое количество сущностей (из-за ограничения числа столбцов в БД). Помните также, что каждый объект, запрашивающий диапазон идентификаторов, блокирует все остальные, что может привести к тупикам в некоторых ситуациях.

Надеюсь, это поможет!

С уважением,

Филип

2 голосов
/ 10 мая 2010

Вы, вероятно, в безопасности с длинным.

В любом случае, у вас нет , чтобы использовать одну и ту же таблицу для всех сущностей. Вы можете установить параметр table на каждом генераторе на другое значение.

...