In the below sample code, Table Name is an input parameter. In this case, how can I avoid SQL injection using sp_executesql
. Below is the sample code, I am trying t
You can enclose the table name in []
SET @sql= N' select * from [' + @tblname + '] where name= @param1 and id= @param2';
However, if you use a two-part naming convention e.g dbo.tablename
, you have to add additional parsing, since [dbo.tablename]
will result to:
Invalid object name [dbo.tablename].
You should parse it so that it'll be equal to dbo.[tablename]
.