Escolha os tipos de dados apropriados
O SQL Server oferece uma ampla variedade de tipos de dados para escolher, e sua escolha pode afetar o desempenho de várias maneiras. Embora o SQL Server possa converter alguns tipos de dados automaticamente (chamamos isso de "conversão implícita"), a conversão pode ser cara e também pode afetar negativamente os planos de consulta. A alternativa é uma conversão explícita, onde você usa a função CAST ou CONVERT em seu código para forçar uma conversão de tipo de dados.
Além disso, escolher tipos de dados muito maiores do que o necessário pode causar desperdício de espaço e exigir mais páginas do que o necessário para serem lidas. É importante escolher os tipos de dados certos para um determinado conjunto de dados, o que reduzirá o armazenamento total necessário para o banco de dados e melhorará o desempenho das consultas executadas.
Nota
Em alguns casos, as conversões não são possíveis. Por exemplo, uma data não pode ser convertida em um bit. As conversões podem afetar negativamente o desempenho da consulta, causando verificações de índice onde as buscas teriam sido possíveis e sobrecarga adicional da CPU a partir da própria conversão.
A imagem abaixo indica em que casos o SQL Server pode fazer uma conversão implícita e em quais casos você deve converter explicitamente tipos de dados em seu código.
O SQL Server oferece um conjunto de tipos de dados fornecidos pelo sistema para todos os dados que podem ser usados em suas tabelas e consultas. O SQL Server permite a criação de tipos de dados definidos pelo usuário no T-SQL ou no .NET framework.