Solved

Stored Procedure

Posted on 1998-12-07
9
180 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
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 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
Turn Insights into Action

Communication across every corner of your business is essential to increase the velocity of your application delivery and support pipeline. Automate, standardize, and contextualize your communication processes with xMatters.

 

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

Turn Insights Into Action

You’ve already invested in ITSM tools, chat applications, automation utilities, and more. Fortify these solutions with intelligent communications so you can drive business processes forward.

With xMatters, you'll never miss a beat.

Question has a verified solution.

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

Slowly Changing Dimension Transformation component in data task flow is very useful for us to manage and control how data changes in SSIS.
Ever needed a SQL 2008 Database replicated/mirrored/log shipped on another server but you can't take the downtime inflicted by initial snapshot or disconnect while T-logs are restored or mirror applied? You can use SQL Server Initialize from Backup…
Viewers will learn how to use the INSERT statement to insert data into their tables. It will also introduce the NULL statement, to show them what happens when no value is giving for any given column.
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.

695 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