forked from DavidWiseman/sqlserver-kit
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathudf_CheckDynamicSQL.sql
58 lines (50 loc) · 1.63 KB
/
udf_CheckDynamicSQL.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
IF OBJECT_ID('dbo.udf_CheckDynamicSQL', 'FN') IS NULL
EXECUTE ('CREATE FUNCTION dbo.udf_CheckDynamicSQL() RETURNS INT AS BEGIN RETURN 1 END;');
GO
ALTER FUNCTION dbo.udf_CheckDynamicSQL(
@dynamicSQL NVARCHAR (MAX)
)
RETURNS NVARCHAR (2000)
AS
/*
.SYNOPSIS
Check Dynamic SQL Statement Syntax
.DESCRIPTION
Check Dynamic SQL Statement Syntax first output result using sys.dm_exec_describe_first_result_set
https://docs.microsoft.com/en-us/sql/relational-databases/system-dynamic-management-views/sys-dm-exec-describe-first-result-set-transact-sql
.PARAMETER @dynamicSQL
Dynamic SQL statement for checking
.EXAMPLE
SELECT dbo.udf_CheckDynamicSQL('SELECT * , FROM sys.databases;');
-- RETURN: Incorrect syntax near the keyword 'FROM'.
.EXAMPLE
SELECT dbo.udf_CheckDynamicSQL('SELECT TOP(1) * FROM sys.databases;');
--RETURN: OK
.NOTE
Author: Eli Leiba
Source link: https://www.mssqltips.com/sqlservertip/4981/sql-server-function-to-check-dynamic-sql-syntax/
*/
BEGIN
DECLARE @Result NVARCHAR (2000);
IF EXISTS (
SELECT 1
FROM sys.dm_exec_describe_first_result_set (@dynamicSQL, NULL, 0)
WHERE [error_message] IS NOT NULL
AND [error_number] IS NOT NULL
AND [error_severity] IS NOT NULL
AND [error_state] IS NOT NULL
AND [error_type] IS NOT NULL
AND [error_type_desc] IS NOT NULL
)
BEGIN
SELECT @Result = [error_message]
FROM sys.dm_exec_describe_first_result_set(@dynamicSQL, NULL, 0)
WHERE column_ordinal = 0;
END
ELSE
BEGIN
SET @Result = 'OK'
END
RETURN (@Result);
END
GO