Compartilhar via


Sintaxe Transact-SQL com suporte do IntelliSense

Este tópico descreve as instruções Transact-SQL e os elementos de sintaxe compatíveis com o IntelliSense no SQL Server 2014.

Instruções com suporte do IntelliSense

No SQL Server 2014, o IntelliSense dá suporte apenas às instruções Transact-SQL mais usadas. Algumas condições gerais do Editor de Consultas do Mecanismo de Banco de Dados podem impedir que o IntelliSense funcione. Para obter mais informações, confira Solucionando problemas do IntelliSense (SQL Server Management Studio).

Observação

O IntelliSense não está disponível para objetos de banco de dados criptografados, como, por exemplo, procedimentos armazenados criptografados ou funções definidas pelo usuário. A ajuda de parâmetros e Informações Rápidas não estão disponíveis para os parâmetros de procedimentos armazenados estendidos e tipos definidos pelo usuário da Integração CLR.

Instrução SELECT

O Editor de Consultas do Mecanismo de Banco de Dados dá suporte ao IntelliSense para os seguintes elementos de sintaxe na instrução SELECT:

SELECT WHERE
FROM ORDER BY
HAVING UNION
FOR GROUP BY
INÍCIO OPTION (dica)

Instruções Transact-SQL adicionais com suporte

O Editor de Consultas do Mecanismo de Banco de Dados também dá suporte ao IntelliSense para instruções Transact-SQL mostradas na tabela a seguir.

Instrução Transact-SQL Sintaxe com suporte
INSERT Toda a sintaxe, exceto a cláusula execute_statement .
UPDATE Toda a sintaxe.
DELETE Toda a sintaxe.
DECLARE @local_variable Toda a sintaxe.
SET @local_variable Toda a sintaxe.
EXECUTE Execução de procedimentos armazenados definidos pelo usuário, procedimentos armazenados do sistema, funções definidas pelo usuário e funções do sistema.
CREATE TABLE Toda a sintaxe.
CREATE VIEW Toda a sintaxe.
CREATE PROCEDURE Toda a sintaxe, com as seguintes exceções:

Não há suporte do IntelliSense para a cláusula EXTERNAL NAME.

Na cláusula AS, o IntelliSense dá suporte apenas às instruções e à sintaxe listadas neste tópico.
ALTER PROCEDURE Toda a sintaxe, com as seguintes exceções:

Não há suporte do IntelliSense para a cláusula EXTERNAL NAME.

Na cláusula AS, o IntelliSense dá suporte apenas às instruções e à sintaxe listadas neste tópico.
USE Toda a sintaxe.

IntelliSense em instruções com suporte

No Editor de Consultas do Mecanismo de Banco de Dados, o IntelliSense dá suporte aos seguintes elementos de sintaxe, quando usados em uma das instruções Transact-SQL com suporte:

  • Todos os tipos de junção, inclusive APPLY

  • PIVOT e UNPIVOT

  • Referências aos seguintes objetos de banco de dados:

    • Bancos de dados e esquemas

    • Tabelas, exibições, funções com valor de tabela e expressões de tabela

    • Colunas

    • Procedimentos e parâmetros de procedimentos

    • Funções escalares e expressões escalares

    • Variáveis locais

    • CTE (expressões de tabela comuns)

  • Objetos de banco de dados referenciados apenas nas instruções CREATE ou ALTER no script ou lote, mas que não existem no banco de dados porque o script ou lote ainda não foi executado. Esses objetos são os seguintes:

    • Tabelas e procedimentos que foram especificados em uma instrução CREATE TABLE ou CREATE PROCEDURE no script ou lote.

    • Alterações em tabelas e procedimentos que foram especificadas em uma instrução ALTER TABLE ou ALTER PROCEDURE no script ou lote.

    Observação

    O IntelliSense não está disponível para as colunas de uma instrução CREATE VIEW até que a instrução CREATE VIEW tenha sido executada.

O IntelliSense não é fornecido para os elementos listados anteriormente quando eles são usados em outras instruções Transact-SQL. Por exemplo, há suporte do IntelliSense para nomes de colunas usados em uma instrução SELECT, mas não para colunas usadas na instrução CREATE FUNCTION.

Exemplos

Em um script ou lote Transact-SQL, o IntelliSense no Editor de Consultas do Mecanismo de Banco de Dados dá suporte apenas às instruções e à sintaxe listadas neste tópico. Os exemplos de código Transact-SQL a seguir mostram as instruções e os elementos de sintaxe com suporte do IntelliSense. Por exemplo, no lote a seguir, o IntelliSense está disponível para a instrução SELECT , quando codificada por si só, mas não quando a instrução SELECT está contida em uma instrução CREATE FUNCTION .

USE AdventureWorks2012;  
GO  
SELECT Name  
FROM Production.Product  
WHERE Name LIKE N'Road-250%' and Color = N'Red';  
GO  
CREATE FUNCTION Production.ufn_Red250 ()  
RETURNS TABLE  
AS  
RETURN   
(  
    SELECT Name  
    FROM AdventureWorks2012.Production.Product  
    WHERE Name LIKE N'Road-250%'  
      AND Color = N'Red'  
);GO  

Essa funcionalidade também se aplica aos conjuntos de instruções Transact-SQL da cláusula AS de uma instrução CREATE PROCEDURE ou ALTER PROCEDURE.

Em um script ou lote Transact-SQL, o IntelliSense dá suporte a objetos que tenham sido especificados em uma instrução CREATE ou ALTER; no entanto, esses objetos não existem no banco de dados, porque as instruções não foram executadas. Por exemplo, você pode digitar o seguinte código no Editor de Consultas:

USE MyTestDB;  
GO  
CREATE TABLE MyTable  
    (PrimaryKeyCol   INT PRIMARY KEY,  
    FirstNameCol      NVARCHAR(50),  
   LastNameCol       NVARCHAR(50));  
GO  
SELECT   

Após digitar SELECT, o IntelliSense listará PrimaryKeyCol, FirstNameCole LastNameCol como possíveis elementos na lista de seleção, mesmo que o script não tenha sido executado e MyTable ainda não exista em MyTestDB.