MSSQLSERVER_1505
Aplica-se: SQL Server
Detalhes
Atributo | Valor |
---|---|
Nome do produto | SQL Server |
ID do evento | 1505 |
Origem do Evento | MSSQLSERVER |
Componente | SQLEngine |
Nome simbólico | DUP_KEY |
Texto da mensagem | CREATE UNIQUE INDEX foi encerrado porque uma chave duplicada foi encontrada para o nome do objeto '%.*ls' e o nome do índice '%.*ls'. O valor da chave duplicada é %ls. |
Explicação
Esse erro ocorre quando você tenta criar um índice exclusivo e mais de uma linha da tabela contém o valor duplicado especificado. Um índice exclusivo é criado quando você cria um índice e especifica a palavra-chave UNIQUE ou quando cria uma restrição UNIQUE. A tabela não pode conter linhas que tenham valores duplicados nas colunas definidas no índice ou na restrição.
Considere os dados da seguinte tabela Employee:
Sobrenome | Nome | JobTitle | HireDate |
---|---|---|---|
Walters | Rob | Designer de ferramentas sênior | 2004-11-19 |
Marrom | Kevin | Marketing Assistant | NULO |
Marrom | Jo | Engenheiro de design | NULO |
Walters | Rob | Designer de ferramentas | 2001-08-09 |
Não é possível criar um índice exclusivo com as combinações de coluna LastName ou LastName e FirstName devido aos valores duplicados nas linhas.
Menos óbvia é a possibilidade de ocorrer uma violação de exclusividade na coluna HireDate. Para fins de indexação, valores NULL são comparados como iguais. Portanto, você não poderá criar um índice exclusivo ou uma restrição exclusiva se os valores de chave forem NULL em mais de uma linha. Considerando os dados acima, não é possível criar um índice exclusivo com base nas combinações de coluna HireDate ou LastName e HireDate.
A mensagem de erro 1505 retorna a primeira linha que viola a restrição de exclusividade. Pode haver outras linhas duplicadas na tabela. Para encontrar todas as linhas duplicadas, consulte a tabela especificada e use as cláusulas GROUP BY e HAVING para reportar essas linhas. Por exemplo, a consulta a seguir retorna as linhas da tabela Employee que têm nomes e sobrenomes duplicados.
SELECT Sobrenome, Nome, count(*) FROM dbo. Funcionário GROUP BY Sobrenome, Nome HAVING count(*) > 1;
Ação do usuário
Considere as soluções descritas a seguir.
Adicione ou remova colunas na definição do índice ou da restrição para criar uma composição exclusiva. No exemplo anterior, adicionar uma coluna MiddleName à definição do índice ou da restrição pode resolver o problema de duplicação.
Selecione colunas definidas como NOT NULL quando escolher colunas para um índice exclusivo ou para uma restrição exclusiva. Isso elimina a possibilidade de ocorrer uma violação de exclusividade gerada quando mais de uma linha contiver NULL nos valores de chave.
Se os valores duplicados forem o resultado de erros de entrada de dados, corrija os dados manualmente e, em seguida, crie o índice ou a restrição. Para obter informações sobre como remover linhas duplicadas em uma tabela, examine Remover linhas duplicadas de uma tabela do SQL Server.
Confira também
CREATE INDEX (Transact-SQL)
Criar índices exclusivos
Criar restrições exclusivas