Índices em colunas computadas
Você pode definir índices em colunas computadas contanto que os seguintes requisitos sejam satisfeitos:
Requisitos de propriedade
Requisitos de determinismo
Requisitos de precisão
Requisitos de tipo de dados
Requisitos de opção SET
Requisitos de propriedade
Todas as referências de função na coluna computada devem ter o mesmo proprietário da tabela.
Requisitos de determinismo
Importante
Expressões são determinísticas se elas sempre retornarem o mesmo resultado para um conjunto de entradas especificado. A propriedade IsDeterministic da função COLUMNPROPERTY relata se um computed_column_expression é determinístico.
A computed_column_expression deve ser determinística. Uma computed_column_expression é determinística quando uma ou mais das seguintes opções é verdadeira:
Todas as funções mencionadas pela expressão são determinísticas e precisas. Essas funções incluem as funções definidas pelo usuário e internas. Para obter mais informações, veja Funções determinísticas e não determinísticas. Funções podem ser imprecisas se a coluna computada for PERSISTED. Para obter mais informações, veja Criando índices em colunas computadas persistentes , mais adiante neste tópico.
Todas as colunas mencionadas na expressão vêm da tabela que contém a coluna computada.
Nenhuma referência de coluna recebe dados de várias linhas. Por exemplo, funções de agregação como SUM ou AVG dependem de dados de várias linhas e criam uma computed_column_expression não determinística.
A computed_column_expression não tem acesso a dados do sistema nem a dados do usuário.
Qualquer coluna computada que contenha uma expressão CLR (Common Language Runtime) deve ser determinística e marcada como PERSISTED antes que a coluna possa ser indexada. Expressões de tipo de dado CLR definido pelo usuário são permitidas em definições de coluna computada. Colunas computadas cujo tipo é um tipo de dado CLR definido pelo usuário podem ser indexadas contanto que o tipo seja comparável. Para obter mais informações, veja Tipos CLR definidos pelo usuário.
Observação
Quando você se refere a literais de cadeia de caracteres do tipo de dados de data em colunas computadas indexadas em SQL Server, recomendamos converter explicitamente o literal para o tipo de data desejado usando um estilo de formato de data determinístico. Para obter uma lista de estilos de formato de data determinísticos, veja CAST e CONVERT. Expressões que envolvem conversão implícita de cadeias de caracteres para tipos de dados de data são consideradas não determinísticas, a menos que o nível de compatibilidade de banco de dados seja definido como 80 ou abaixo disso. Isso ocorre porque os resultados dependem das configurações de LANGUAGE e DATEFORMAT da sessão de servidor. Por exemplo, os resultados da expressão CONVERT (datetime, '30 listopad 1996', 113)
dependem da configuração LANGUAGE porque a cadeia de caracteres '30 listopad 1996
' significa meses diferentes em idiomas. Da mesma forma, na expressão DATEADD(mm,3,'2000-12-01')
, o Mecanismo de Banco de Dados interpreta a cadeia '2000-12-01'
de caracteres com base na configuração DATEFORMAT.
A conversão implícita de dados de caracteres não Unicode entre ordenações também é considerada não determinística, a menos que o nível de compatibilidade seja definido como 80 ou abaixo disso.
Quando o nível da configuração da compatibilidade de banco de dados é 90, você não pode criar índices em colunas computadas que contêm essas expressões. Porém, a existência de colunas computadas com essas expressões de um banco de dados atualizado é sustentável. Se você usar colunas computadas indexadas que contêm conversões implícitas de cadeia de caracteres para datas; para evitar possível corrupção de índice, verifique se as configurações LANGUAGE e DATEFORMAT estão consistentes em seus bancos de dados e aplicativos.
Requisitos de precisão
A computed_column_expression deve ser precisa. Uma computed_column_expression é precisa quando uma ou mais das seguintes opções é verdadeira:
Não é uma expressão de tipos de dados
float
oureal
.Não usa
float
ou tipo de dadosreal
em sua definição. Por exemplo, na instrução a seguir, a colunay
éint
e determinística mas não é precisa.CREATE TABLE t2 (a int, b int, c int, x float, y AS CASE x WHEN 0 THEN a WHEN 1 THEN b ELSE c END);
Observação
Qualquer expressão float
ou real
é considerada imprecisa e não pode ser uma chave de um índice; uma expressão float
ou real
pode ser usada em uma exibição indexada mas não como uma chave. Isso também é verdade para colunas computadas. Qualquer função, expressão, ou função definida pelo usuário será considerada imprecisa se contiver qualquer expressão float
ou real
. Isso inclui as lógicas (comparações).
A propriedade IsPrecise da função COLUMNPROPERTY relata se uma computed_column_expression é precisa.
Requisitos de tipo de dados
A computed_column_expression definida para a coluna computada não pode ser avaliada para os
text
tipos de dados ,ntext
ouimage
.Colunas computadas derivadas de
image
,ntext
,text
,varchar(max)
,nvarchar(max)
,varbinary(max)
, e tipos de dadosxml
podem ser indexados contanto que o tipo de dados de coluna computada seja permitido como coluna de índice chave.Colunas computadas derivadas de
image
,ntext
, e tipos de dadostext
podem ser colunas não chave (inclusas) em um índice não clusterizado contanto que o tipo de dados da coluna computada seja permitida como coluna de índice não chave.
Requisitos de opção SET
A opção de nível de conexão ANSI_NULLS deve ser definida como ON quando a instrução CREATE TABLE ou ALTER TABLE que define a coluna computada é executada. A função OBJECTPROPERTY relata se a opção está ativa pela propriedade IsAnsiNullsOn .
A conexão na qual o índice é criado e todas as conexões que tentam instruções INSERT, UPDATE ou DELETE que alterarão valores no índice, deve ter seis opções de SET definidas como ON e uma opção definida como OFF. O otimizador ignora um índice em uma coluna computada para qualquer instrução SELECT executada por uma conexão que não tenha essas mesmas opções de configuração.
A opção de NUMERIC_ROUNDABORT deve ser definida como OFF e as opções seguintes devem ser definidas como ON:
ANSI_NULLS
ANSI_PADDING
ANSI_WARNINGS
ARITHABORT
CONCAT_NULL_YIELDS_NULL
QUOTED_IDENTIFIER
A definição de ANSI_WARNINGS como ON definirá ARITHABORT implicitamente como ON quando o nível de compatibilidade do banco de dados estiver definido como 90 ou mais.
Criando índices em colunas computadas persistentes
Você pode criar um índice em uma coluna computada que está definida com uma expressão determinística, mas imprecisa, se a coluna for marcada como PERSISTED na instrução CREATE TABLE ou ALTER TABLE. Isso significa que o Mecanismo de Banco de Dados usa esses valores persistentes quando cria um índice na coluna e quando o índice é referenciado em uma consulta. Essa opção permite que você crie um índice em uma coluna computada quando .NET Framework, é determinístico e preciso.