Solved

Stored Procedure

Posted on 1998-12-07
9
178 Views
Last Modified: 2010-03-19
Hi
I am trying to pass parameters to a stored procedure , this paremeter will be used in an "in" clause. Since i cannot pass an array as parameter i am trying to concatenate the different values in the or class into a string and send as a varchar and execute the SQL in the procedure using EXEC statement. But sometimes this concatenated "in" clause parameters exceeds 255 characters. so i cannot pass it as a varchar. what would be the solution
0
Comment
Question by:varsha2
  • 5
  • 2
  • 2
9 Comments
 
LVL 2

Expert Comment

by:tschill120198
ID: 1092097
You could pass the values in using a varchar field, parse each value into a table, and join to that table in your query instead of using "in"... performance won't be optimal due to the parsing, though.
0
 

Author Comment

by:varsha2
ID: 1092098
I cannot pass the parameter using a varchar field because all the parameters together exceeds 255 characters
0
 
LVL 2

Expert Comment

by:tschill120198
ID: 1092099
How about using multiple varchar parameters?
0
PRTG Network Monitor: Intuitive Network Monitoring

Network Monitoring is essential to ensure that computer systems and network devices are running. Use PRTG to monitor LANs, servers, websites, applications and devices, bandwidth, virtual environments, remote systems, IoT, and many more. PRTG is easy to set up & use.

 

Author Comment

by:varsha2
ID: 1092100
I craete the in clause dynamically and i may not be able to determine how many varchar i might need to send as input parameter. this basically prevents me from determining how many input parameters the stored procedure can have
0
 
LVL 2

Accepted Solution

by:
tschill120198 earned 50 total points
ID: 1092101
Surely there must be a limit at some point... say, 10 varchar parameters?  20? 30?  They don't all have to be used, so if a particular query doesn't need all of them, they can default to null; the sproc doesn't parse them if they are null.  This is probably your best solution.
An alternative solution would be to have a seperate sproc that is called repeatedly (once for each value you want to query against) and this sproc inserts the values into a table.  When all values have been entered, you call the sproc that performs the main query.


0
 
LVL 1

Expert Comment

by:ivanh
ID: 1092102
The quick answer would be as a text datatype, but I'm not sure
what that does for performance.  I use it on one of my queries
for the same type of reason and I don't notice any performance problems.
0
 
LVL 2

Expert Comment

by:tschill120198
ID: 1092103
Agreed... a text parameter would be a cleaner solution to the parameter issue.  But how would you parse the text field for the different values you are searching on?
0
 
LVL 1

Expert Comment

by:ivanh
ID: 1092104
He said that he was going to concatenate the string into the
format for execution in the IN statement and then run the EXEC statement to run the query.

EXEC ("select * from mytable where name in (" + in_str + ")")

in_str would be something like "'a','b','c','d'".
0
 
LVL 2

Expert Comment

by:tschill120198
ID: 1092105
ivanh is correct... his answer should work.
0

Featured Post

What is SQL Server and how does it work?

The purpose of this paper is to provide you background on SQL Server. It’s your self-study guide for learning fundamentals. It includes both the history of SQL and its technical basics. Concepts and definitions will form the solid foundation of your future DBA expertise.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Everyone has problem when going to load data into Data warehouse (EDW). They all need to confirm that data quality is good but they don't no how to proceed. Microsoft has provided new task within SSIS 2008 called "Data Profiler Task". It solve th…
I have a large data set and a SSIS package. How can I load this file in multi threading?
Viewers will learn how the fundamental information of how to create a table.
Viewers will learn how to use the SELECT statement in SQL to return specific rows and columns, with various degrees of sorting and limits in place.

828 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question