Dynamic Variables and Stored Procedures

Question:
I need to pass the @TheVar variable to the stored procedure’s IN statement but I keep getting zero records. If I type this statement into the SQL…

WHERE Name IN ('John', 'Frank', 'Tom')

the statement works fine; 20 records are returned.

-----------------------------------EXECUTE the_proc "'John', 'Frank', 'Tom'"-----------------------------------DECLARE PROCEDURE the_proc @TheVar nvarchar(40) ASSELECT COUNT(FieldName) FROM Clients WHERE Name IN (@TheVar)-----------------------------

Do you have any ideas? I use MS SQL Server 7.0 SP2.

Answer:
If you want to use variables as part of your SQL statement you need to modify it to call the EXECUTE statement. I created a Clients table with a single Name field of varchar(255) with records for John, Frank, and Tom. Then I created a stored procedure (similar to yours) that uses the input variable to build the IN clause like this:

CREATE PROCEDURE [email protected] varchar(255) ASEXEC ('SELECT COUNT(Name) FROM Clients WHERE Name IN (' + @TheVar + ')')

As you can see, it builds the SELECT statement using the variable and then the EXEC statement runs it.

The syntax to call this procedure is:

GetClients "'John', 'Tom', 'Frank'"----------- 3(1 row(s) affected)

Share the Post:
Share on facebook
Share on twitter
Share on linkedin

Overview

The Latest

homes in the real estate industry

Exploring the Latest Tech Trends Impacting the Real Estate Industry

The real estate industry is changing thanks to the newest technological advancements. These new developments — from blockchain and AI to virtual reality and 3D printing — are poised to change how we buy and sell homes. Real estate brokers, buyers, sellers, wholesale real estate professionals, fix and flippers, and beyond may

man on floor with data

DevX Quick Guide to Data Ingestion

One of the biggest trends of the 21st century is the massive surge in internet usage. With major innovations such as smart technology, social media, and online shopping sites, the internet has become an essential part of everyday life for a large portion of the population. Due to this internet

payment via phone

7 Ways Technology Has Changed Traditional Payments

In today’s digital world, technology has changed how we make payments. From contactless cards to mobile wallets, it’s now easier to pay for goods and services without carrying cash or using a checkbook. This article will look at seven of the most significant ways technology has transformed traditional payment methods.