Лучший способ обрабатывать уникальные ограничения при использовании Entity Framework - PullRequest
0 голосов
/ 31 октября 2010

Я использую Entity Framework 4.0 для доступа к данным в таблице с уникальным ограничением столбца. Если ограничение нарушается, возникает исключение, когда я вызываю SaveChanges (), как и ожидалось. Мой вопрос заключается в том, должен ли я разрешить исключение в первую очередь. В качестве альтернативы я мог бы сделать выбор, чтобы избежать вставки дублирующих данных (я предполагаю, что транзакция будет необходима).

Какова общепринятая лучшая практика в этом сценарии?

1 Ответ

3 голосов
/ 31 октября 2010

Как правило, избегать исключения - создание исключения является довольно сложной и ресурсоемкой операцией.Так что, если вы можете легко проверить, существует ли уникальное значение ключа, то я, вероятно, сделал бы это.Предполагая, что у вас есть уникальный индекс или уникальное ограничение для этого столбца на уровне базы данных, тогда (по крайней мере для SQL Server) уже есть индекс для этого столбца, поэтому проверка определенного значения будет довольно простой и не будет иметь огромной производительностиВлияние.

Другой вопрос: как часто вы думаете, что это произойдет?Один раз в день?Раз в пару недель?Несколько раз в минуту?Если это случается довольно редко - один раз в голубой луне - я бы не стал пытаться сначала проверить - в таком случае, просто позвольте исключению произойти и обработайте его.Как дорого стоит сначала проверить, и как часто это происходит?Если вы можете проверить это очень легко -> сделайте это, во что бы то ни стало!Но если это довольно сложная операция для проверки, и это происходит очень редко, просто обработайте исключение.

...