SQL Server: максимальная длина символа в именах объектов

121

Какова максимальная длина символа имени объекта (например, ограничения, столбца) в SQL Server 2008?

jrara
источник

Ответы:

147

128 символов. Это максимальная длина типа sysnameданных ( nvarchar(128)).

Мартин Смит
источник
56

Да, это 128, за исключением временных таблиц , имена которых могут содержать не более 116 символов. Здесь это прекрасно объяснено .

А проверку можно легко выполнить с помощью следующего сценария, который ранее содержался в сообщении в блоге:

DECLARE @i NVARCHAR(800)
SELECT @i = REPLICATE('A', 116)
SELECT @i = 'CREATE TABLE #'+@i+'(i int)'
PRINT @i
EXEC(@i)
Jaime
источник
Я думаю, что под «компробированием» вы могли иметь в виду «испытание» или «проверку». Я прав?
Stephen G Tuggy
20

Вы также можете использовать этот скрипт для получения дополнительной информации:

EXEC sp_server_info

Результат будет примерно таким:

attribute_id | attribute_name        | attribute_value
-------------|-----------------------|-----------------------------------
           1 | DBMS_NAME             | Microsoft SQL Server
           2 | DBMS_VER              | Microsoft SQL Server 2012 - 11.0.6020.0
          10 | OWNER_TERM            | owner
          11 | TABLE_TERM            | table
          12 | MAX_OWNER_NAME_LENGTH | 128
          13 | TABLE_LENGTH          | 128
          14 | MAX_QUAL_LENGTH       | 128
          15 | COLUMN_LENGTH         | 128
          16 | IDENTIFIER_CASE       | MIXED
                                    
                                    
                                    
GorkemHalulu
источник