Взгляните на SQL Server - установите случайные числа на основе , в которых есть очень подробное объяснение.
Чтобы подвести итог, следующий код генерирует случайное число от 0 до 13 включительно с нормализованным распределением:
ABS(CHECKSUM(NewId())) % 14
Чтобы изменить свой диапазон, просто измените число в конце выражения. Будьте особенно осторожны, если вам нужен диапазон, который включает как положительные, так и отрицательные числа. Если вы сделаете это неправильно, можно удвоить число 0.
Небольшое предупреждение для математических орехов в комнате: в этом коде есть очень небольшое смещение. CHECKSUM()
приводит к числам, которые являются одинаковыми по всему диапазону типа данных sql Int, или, по крайней мере, настолько близкими, насколько может показать мое (редакторское) тестирование. Однако будет некоторое смещение, когда CHECKSUM () выдаст число в самом верхнем конце этого диапазона. Каждый раз, когда вы получаете число между максимально возможным целым числом и последним точным кратным размера желаемого диапазона (в данном случае 14) перед этим максимальным целым числом, эти результаты предпочтительнее, чем оставшаяся часть вашего диапазона, которая не может быть получена из это последнее кратное 14.
В качестве примера представьте, что весь диапазон типа Int равен только 19. 19 - это наибольшее возможное целое число, которое вы можете удерживать. Когда CHECKSUM () приводит к 14-19, они соответствуют результатам 0-5. Эти числа будут сильно предпочтительнее 6-13, потому что CHECKSUM () в два раза чаще генерирует их. Это проще продемонстрировать визуально. Ниже представлен весь возможный набор результатов для нашего воображаемого целочисленного диапазона:
Checksum Integer: 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
Range Result: 0 1 2 3 4 5 6 7 8 9 10 11 12 13 0 1 2 3 4 5
Вы можете видеть здесь, что есть больше шансов произвести некоторые числа, чем другие: смещение. К счастью, фактический диапазон типа Int на намного больше ... настолько, что в большинстве случаев смещение почти невозможно обнаружить. Однако об этом следует знать, если вы обнаружите, что делаете это для серьезного кода безопасности.