Solved

mysql stored proc parameter question

Posted on 2011-09-06
8
527 Views
Last Modified: 2012-05-12
Hi,

I have a field with text that has numbers separated by commas. I want to only return lines that have the passed number in the field (between commas).

Is there a way i can pass a number as my stored proc param and include it in my query?

Thanks in advance
0
Comment
Question by:basil365
  • 4
  • 2
  • 2
8 Comments
 
LVL 28

Expert Comment

by:strickdd
ID: 36490039
you can run the field through a split function, but that can be substantial overhead. The best way I have come up with is to make sure the field always starts and ends with a comma and the searching

where MyField LIKE '%,Number,%'
0
 

Author Comment

by:basil365
ID: 36490077
i tried that but i dont know how to concatenate the variable 'Number' into the like clause?
0
 
LVL 28

Expert Comment

by:strickdd
ID: 36490186
I belive in MySQL, it is simply:

columnName LIKE '%$MySearchTerm%'
0
Netscaler Common Configuration How To guides

If you use NetScaler you will want to see these guides. The NetScaler How To Guides show administrators how to get NetScaler up and configured by providing instructions for common scenarios and some not so common ones.

 
LVL 8

Accepted Solution

by:
stalhw earned 300 total points
ID: 36490193
ok, here's an example:

CREATE PROCEDURE foo.bar (IN _Number varchar(20) )
BEGIN
SELECT * FROM someTable
WHERE MyField LIKE CONCAT('%,',_Number,',%');
END

and if your MyField doesn't start and end with a comma, you'll need to do more in the WERE clause
WHERE MyField LIKE CONCAT('%,',_Number,',%')
OR MyField LIKE CONCAT(_Number,',%')
OR MyField LIKE CONCAT('%,',_Number)




0
 
LVL 28

Expert Comment

by:strickdd
ID: 36490225
These two can return false positives:

OR MyField LIKE CONCAT(_Number,',%')
OR MyField LIKE CONCAT('%,',_Number)

For example, if the number you are looking for is "100" and the data looks like:

100,1,10
1100,1,10
1,10,100
1,10,1001

The two statements will return true for all the records. If you don't start and end with a comma, then you will need this:

SELECT * FROM someTable
WHERE CONCAT(',', MyField, ',') LIKE CONCAT('%,',_Number,',%');

That will ensure no false positives.
0
 
LVL 8

Expert Comment

by:stalhw
ID: 36490334
@strickdd:
No they won't return false positive...
Try it, you'll see...

a LIKE without a % in the beginning means the string must start with that we are showing so
1100,1,10 wouldn't match
same for the ending
1,10,1001 wouldn't match either

I agree that
WHERE CONCAT(',', MyField, ',') LIKE CONCAT('%,',_Number,',%');
will work (and is simple),
but my queries wouldn't not produce false positive, you are wrong about that, try it:
SELECT 1 FROM sometable WHERE '1,10,1001' LIKE '%,100'
it will return nothing, so no false positive...

0
 
LVL 28

Assisted Solution

by:strickdd
strickdd earned 200 total points
ID: 36490352
Ah, point taken. I misread the query thinking you left the "%" before the number.
0
 

Author Closing Comment

by:basil365
ID: 36494168
Thanks to you both
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

Read about achieving the basic levels of HRIS security in the workplace.
Performance in games development is paramount: every microsecond counts to be able to do everything in less than 33ms (aiming at 16ms). C# foreach statement is one of the worst performance killers, and here I explain why.
Video by: Steve
Using examples as well as descriptions, step through each of the common simple join types, explaining differences in syntax, differences in expected outputs and showing how the queries run along with the actual outputs based upon a simple set of dem…
Polish reports in Access so they look terrific. Take yourself to another level. Equations, Back Color, Alternate Back Color. Write easy VBA Code. Tighten space to use less pages. Launch report from a menu, considering criteria only when it is filled…

839 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