В sql server имеет значение, если я определяю столбец varchar длиной 32 или 128?





Заметной разницы быть не должно, поскольку серверная часть будет хранить только тот объем данных, который вы вставляете в этот столбец. Он не заполняется до полного размера поля, как в столбце char.
Обновлено: для получения дополнительной информации этот связь должен быть полезен.
Не должно. Он просто определяет максимальную длину, которую он может вместить, фактическая используемая длина зависит от вставленных данных.
варчар - это поле переменного символа. Это означает, что он может содержать текстовые данные определенной длины. Varchar (32) может содержать только 32 символа, тогда как varchar (128) может содержать 128 символов. Если бы я попытался ввести «12345» в поле varchar (3); это данные, которые будут храниться:
«123»
Число «45» будет «усечено» (потеряно).
Они очень полезны в случаях, когда вы знаете, что определенное поле будет иметь только (или только должен) определенную максимальную длину. Например: почтовый индекс или аббревиатура штата. Фактически, они обычно используются почти для всех типов текстовых данных (таких как имена / адреса / и так далее), но в этих случаях вы должны быть осторожны, чтобы указанное вами число было разумным максимумом для типа данных, которые будут заполнять этот столбец.
Однако вы также должны быть осторожны при их использовании, чтобы позволить пользователю вводить только максимальное количество символов, которое поддерживает поле. В противном случае это может привести к путанице, когда он усекает вводимые пользователем данные.
Это не бык. Помимо имен и адресов, я встречал много полей varchar, которые скатертично забиты экскрементами.
Вы спрашиваете: имеет ли значение, если длина столбца равна МОЩНОСТИ ДВУХ? (32/64/128/256 и т. д.) Ответ на ЭТО вопрос очень разный.