Skip to content

Latest commit

 

History

History
113 lines (95 loc) · 3.64 KB

File metadata and controls

113 lines (95 loc) · 3.64 KB
description SET NOEXEC (Transact-SQL)
title SET NOEXEC (Transact-SQL) | Microsoft Docs
ms.custom
ms.date 06/10/2016
ms.prod sql
ms.prod_service database-engine, sql-database
ms.reviewer
ms.technology t-sql
ms.topic reference
f1_keywords
NOEXEC_TSQL
SET_NOEXEC_TSQL
SET NOEXEC
NOEXEC
dev_langs
TSQL
helpviewer_keywords
queries [SQL Server], compiling
SET NOEXEC statement
compiling queries [SQL Server]
NOEXEC option
ms.assetid ba56fba1-af9b-4459-b6e4-5d7e71a7630b
author WilliamDAssafMSFT
ms.author wiassaf

SET NOEXEC (Transact-SQL)

[!INCLUDE SQL Server SQL Database]

Compiles each query but does not execute it.

Topic link icon Transact-SQL Syntax Conventions

Syntax

  
SET NOEXEC { ON | OFF }  

[!INCLUDEsql-server-tsql-previous-offline-documentation]

Remarks

When SET NOEXEC is ON, [!INCLUDEssNoVersion] parses and compiles each batch of [!INCLUDEtsql] statements but does not execute them. When SET NOEXEC is OFF, all batches are executed after compilation. NOEXEC supports deferred name resolution; if one or more referenced objects in the batch don't exist, no error will be thrown.

The execution of statements in [!INCLUDEssNoVersion] has two phases: compilation and execution. This setting is useful for having [!INCLUDEssNoVersion] validate the syntax and object names in [!INCLUDEtsql] code when executing. It is also useful for debugging statements that would generally be part of a larger batch of statements.

The setting of SET NOEXEC is set at execute or run time and not at parse time.

Permissions

Requires membership in the public role.

Examples

The following example uses NOEXEC with a valid query, a query with an object name that is not valid, and a query with incorrect syntax.

USE AdventureWorks2012;  
GO  
PRINT 'Valid query';  
GO  
-- SET NOEXEC to ON.  
SET NOEXEC ON;  
GO  
-- Inner join.  
SELECT e.BusinessEntityID, e.JobTitle, v.Name  
FROM HumanResources.Employee AS e   
   INNER JOIN Purchasing.PurchaseOrderHeader AS poh  
   ON e.BusinessEntityID = poh.EmployeeID  
   INNER JOIN Purchasing.Vendor AS v  
   ON poh.VendorID = v.BusinessEntityID;  
GO  
-- SET NOEXEC to OFF.  
SET NOEXEC OFF;  
GO  
  
PRINT 'Invalid object name';  
GO  
-- SET NOEXEC to ON.  
SET NOEXEC ON;  
GO  
-- Function name uses is a reserved keyword.  
USE AdventureWorks2012;  
GO  
CREATE FUNCTION dbo.Values(@BusinessEntityID int)  
RETURNS TABLE  
AS  
RETURN (SELECT PurchaseOrderID, TotalDue  
   FROM dbo.PurchaseOrderHeader  
   WHERE VendorID = @BusinessEntityID);  
  
-- SET NOEXEC to OFF.  
SET NOEXEC OFF;  
GO  
  
PRINT 'Invalid syntax';  
GO  
-- SET NOEXEC to ON.  
SET NOEXEC ON;  
GO  
-- Built-in function incorrectly invoked.  
SELECT *  
FROM fn_helpcollations;  
-- Reset SET NOEXEC to OFF.  
SET NOEXEC OFF;  
GO  

See Also

SET Statements (Transact-SQL)
SET SHOWPLAN_ALL (Transact-SQL)
SET SHOWPLAN_TEXT (Transact-SQL)