T-SQL Procedure, scalar variable error even after successful updation

Aqib
--sp_executesql version
    --SET @SQLQUERY = 'UPDATE @TableName SET Brief = @Brief,
    --               [Full] = @Full,                        
    --               CreatedBy = @CreatedBy,
    --               Department = @Department,
    --               Answer = @Answer WHERE Id=@Id';
 --SET @ParamDefinition=N'@TableName nvarchar(50),@Brief nvarchar(50),@Full nvarchar(MAX),@CreatedBy varchar(256),@Department varchar(256),@Answer nvarchar(MAX),@Id int' 
--  exec sp_executesql @SQLQUERY,@ParamDefinition,@TableName,@Brief,@Full,@CreatedBy,@Department,@Answer,@Id; 

-- exec version
SET @SQLQUERY = 'UPDATE ' + @TableName + ' SET  
                     Brief ='+ @Brief+',
                     [Full] ='+ @Full+',                        
                     CreatedBy ='+ @CreatedBy+',
                     Department ='+ @Department+',
                     Answer ='+@Answer+' WHERE Id='+CAST(@Id as nvarchar(10))

print @SQLQUERY; 
EXEC (@SQLQUERY)

I have used both EXEC and sp_executesql procedures to execute my dynamic query but both are failing.

In case of EXEC the dynamic query is not set to the @SQLQUERY variable (seen after debugging), in case of sp_executesql I get scalar variable error though database is updated and I have already passed everything to it.

Lukasz Szozda

Case is very simple. You cannot parametrize table/column name in UPDATE statement:

SET @SQLQUERY = 'UPDATE @TableName       --here is problem
                 SET    Brief = @Brief, 
                        [Full] = @Full,                        
                        CreatedBy = @CreatedBy,
                        Department = @Department,
                        Answer = @Answer 
                 WHERE Id=@Id';


SET @ParamDefinition=N'@TableName nvarchar(50),@Brief nvarchar(50), 
                       @Full nvarchar(MAX), @CreatedBy varchar(256),
                       @Department varchar(256),@Answer nvarchar(MAX),@Id int' 

EXEC dbo.sp_executesql @SQLQUERY,@ParamDefinition,
                        @TableName,@Brief,@Full,
                        @CreatedBy,@Department,@Answer,@Id;

Use substitution instead:

SET @SQLQUERY = N'UPDATE <tab_name> 
                  SET Brief     = @Brief, 
                     [Full]     = @Full,                        
                     CreatedBy  = @CreatedBy,
                     Department = @Department,
                     Answer     = @Answer 
                  WHERE Id = @Id';

SET @SQLQUERY = REPLACE(@SQLQUERY, '<tab_name>', QUOTENAME(@TableName));

SET @ParamDefinition=N'@Brief nvarchar(50),@Full nvarchar(MAX),
                       @CreatedBy varchar(256),@Department varchar(256),
                       @Answer nvarchar(MAX),@Id int';

EXEC [dbo].[sp_executesql] @SQLQUERY,
                           @ParamDefinition,
                           @Brief,@Full,@CreatedBy, @Department,@Answer,@Id;

Notes:

  • Table name should have SYSNAME datatype.
  • It is a good practice to quote identifiers with QUOTENAME (to avoid potential SQL Injection attacks).
  • I guess @CreatedBy is datetime that is why I do not understand why it is passed as varchar(256).
  • It is a good practice to end every statement with ;. In future versions this will be mandatory.

Collected from the Internet

Please contact [email protected] to delete if infringement.

edited at
0

Comments

0 comments
Login to comment

Related

Can't figure out Scalar Variable Error when Altering Procedure

Must Declare the scalar variable error in Stored Procedure

Stored Procedure error "Must declare the scalar variable"

ajax call not successful even after variable is available

SQL Server - "must declare scalar variable" error message even though I have just declared it

T-SQL Setting a scalar variable with the value of another scalar variable

Could not create procedure Error: Must declare the scalar variable "@TableName"

SQL Server stored procedure: Must declare the scalar variable

Azure SQL | Create Stored Procedure | RequestError: Must declare the scalar variable

T-SQL Stored Procedure error inserting the last variable

Must declare the scalar variable ' ' error in SQL Server

SQL error: must declare a scalar variable

SQL - Must declare the scalar variable error

Dynamix SQL Error "Must declare the scalar variable"

SQL Error - Must declare the scalar variable

After updation Wamp Server 3.1.4 showing error

Updation of the variable

Laravel Database Connection Error even after successful Migration

After creating a stored procedure and querying the table created,returns 'Invalid object name' even after successful creation of the stored procedure

SQL Error (137): Must declare the scalar variable "@sql"

Declare scalar variable SQL

SQL Server - error after executing stored procedure

Dynamic SQL throws error complaining scalar variable is not defined

How to correct the scalar variable declaration error in my SQL job?

How to resolve error with SQL Scalar variable using GETDATE

"Must declare the scalar variable" error in my created SQL trigger

How to resolved error "must declare the scalar variable @var" in call stored procedure by EF?

Error "Must declare the scalar variable" when creating a stored procedure with table parameter

T-SQL stored procedure result into variable

TOP Ranking

  1. 1

    Failed to listen on localhost:8000 (reason: Cannot assign requested address)

  2. 2

    pump.io port in URL

  3. 3

    How to import an asset in swift using Bundle.main.path() in a react-native native module

  4. 4

    Loopback Error: connect ECONNREFUSED 127.0.0.1:3306 (MAMP)

  5. 5

    Compiler error CS0246 (type or namespace not found) on using Ninject in ASP.NET vNext

  6. 6

    BigQuery - concatenate ignoring NULL

  7. 7

    Spring Boot JPA PostgreSQL Web App - Internal Authentication Error

  8. 8

    ggplotly no applicable method for 'plotly_build' applied to an object of class "NULL" if statements

  9. 9

    ngClass error (Can't bind ngClass since it isn't a known property of div) in Angular 11.0.3

  10. 10

    How to remove the extra space from right in a webview?

  11. 11

    Change dd-mm-yyyy date format of dataframe date column to yyyy-mm-dd

  12. 12

    Jquery different data trapped from direct mousedown event and simulation via $(this).trigger('mousedown');

  13. 13

    maven-jaxb2-plugin cannot generate classes due to two declarations cause a collision in ObjectFactory class

  14. 14

    java.lang.NullPointerException: Cannot read the array length because "<local3>" is null

  15. 15

    How to use merge windows unallocated space into Ubuntu using GParted?

  16. 16

    flutter: dropdown item programmatically unselect problem

  17. 17

    Pandas - check if dataframe has negative value in any column

  18. 18

    Nuget add packages gives access denied errors

  19. 19

    Can't pre-populate phone number and message body in SMS link on iPhones when SMS app is not running in the background

  20. 20

    Generate random UUIDv4 with Elm

  21. 21

    Client secret not provided in request error with Keycloak

HotTag

Archive