Alguém pode me explicar o abaixo. Usei a consulta abaixo para obter as informações das colunas da tabela, mas o comprimento máximo parece ser x * 2 do comprimento real da coluna. Quero dizer, se eu tiver um col com o tipo de dados nvarchar (10), a saída da minha consulta terá o valor max_length como '20'. Estou um pouco confuso aqui.. Estou olhando para o caminho certo?
SELECT
c.name ColName,
t.Name 'Data type',
c.max_length 'Max Length',
c.precision ,
c.scale ,
c.is_nullable,
ISNULL(i.is_primary_key, 0) 'Primary Key'
FROM
sys.columns c
INNER JOIN
sys.types t ON c.user_type_id = t.user_type_id
LEFT OUTER JOIN
sys.index_columns ic ON ic.object_id = c.object_id AND ic.column_id = c.column_id
LEFT OUTER JOIN
sys.indexes i ON ic.object_id = i.object_id AND ic.index_id = i.index_id
WHERE
c.object_id = OBJECT_ID('Table Name')
A coluna
max_length
é o comprimento máximo da coluna em bytes . Para os tipos de string do conjunto de caracteres nacionais (NCHAR e NVARCHAR), cada caractere requer dois bytes, então NCHAR(10) teria ummax_length
valor de 20.