Megjegyzés
Az oldalhoz való hozzáféréshez engedély szükséges. Megpróbálhat bejelentkezni vagy módosítani a címtárat.
Az oldalhoz való hozzáféréshez engedély szükséges. Megpróbálhatja módosítani a címtárat.
A következőkre vonatkozik:SQL Server
Azure SQL Database
Felügyelt Azure SQL-példány
SQL-adatbázis a Microsoft Fabricben
Minden lekérdezést lefordít, de nem hajtja végre.
Transact-SQL szintaxis konvenciók
Szemantika
SET NOEXEC { ON | OFF }
Megjegyzések
Amikor a SET NOEXEC bekapcsolt, az SQL Server minden Transact-SQL utasításból álló csomagot elemzi és fordít, de nem hajtja végre azokat. Amikor a SET NOEXEC KIKAPCSOLVA, az összes tétel a fordítás után fut le. A NOEXEC támogatja a halasztott névfeloldást; Ha egy vagy több hivatkozott objektum nem létezik a batchben, nem történik hiba.
Az utasítások SQL Serverben történő végrehajtása két fázisból áll: fordítás és végrehajtás. Ez a beállítás hasznos ahhoz, hogy az SQL Server érvényesítse a szintaxist és az objektumneveket Transact-SQL kódban végrehajtáskor. Hasznos továbbá olyan állítások hibakeresésére is, amelyek általában egy nagyobb tétel része lennének.
A SET NOEXEC beállítása végrehajtási vagy futási időben van beállítva, nem pedig parze-időben.
Permissions
A nyilvános szerepkörhöz tagságra van szükség.
Példák
A következő példa NOEXEC érvényes lekérdezéssel, egy olyan lekérdezéssel, amelynek objektum neve nem érvényes, és egy hibás szintaxissal rendelkező lekérdezés.
USE AdventureWorks2022;
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 used is a reserved keyword.
USE AdventureWorks2022;
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
Lásd még:
SET-utasítások (Transact-SQL)
SET SHOWPLAN_ALL (Transact-SQL)
SET SHOWPLAN_TEXT (Transact-SQL)