Solved

NEED TO BUILT A REPORT LIKE THIS

Posted on 2011-02-18
3
264 Views
Last Modified: 2012-05-11
I HAVE ATTACHED TWO FILES ONE IS REPORT FORMAT AND ONE IS STORED PROC.

NEED HELP TO PASS MULTIPLE DIVSION NAMES IN THE @DIVISIONNAME PARAMETER

LIKE @DIVISIONNAME= 'dIVISION DESCRIPTION 2,DIVISION DESCRIPTION 3'

NOW IT ACCEPTS ONLY ONE LIKE THIS

@DIVISIONNAME= 'dIVISION DESCRIPTION 2'

ITS URGENT PLEASE
rpteBidProjectDetailCosting.pdf
StoredProc.txt
0
Comment
Question by:sqlcurious
  • 2
3 Comments
 
LVL 37

Accepted Solution

by:
ValentinoV earned 500 total points
ID: 34932500
I think you'll find the answer in the following article: http://www.experts-exchange.com/Microsoft/Development/MS-SQL-Server/MS-SQL_Reporting/A_2002-Reporting-On-Data-From-Stored-Procedures-part-2.html

It explains in detail how you can pass a multi-valued parameter to a stored procedure, exactly what you're looking for :-)
0
 

Author Comment

by:sqlcurious
ID: 34965671
please check the stored proc too is it possible from this stored proc if not can you modify
0
 
LVL 37

Expert Comment

by:ValentinoV
ID: 34967569
The following code assumes that the function called list_to_tbl as shown in the code snippet below exists.
(Please note: this function differs slightly from the one in the article because you're dealing with strings instead of numbers)

To filter on your divisions, instead of

 set @SQL= @Sql + ' And D.DivisionName LIKE ''%'+@DivisionName+'%''' 

Open in new window


you can do

set @SQL= @Sql + ' And D.DivisionName IN (select * from list_to_tbl(@DivisionName))' 

Open in new window


Please note that the declaration of your @DivisionName parameter should take into account that multiple values are passed.  Which means that the length of the parameter should be: maximum length of division name multiplied by maximum number of divisions that the report user will select.

One more note: I notice that you've also got DivisionIDs in your database.  It would be better if you could set up your parameter to use that ID as value for the parameter.  That way you get a list of comma-separated numbers (as explained in the article referenced earlier) instead of strings.  Obviously that means that your stored proc code would also need to change a bit.
That's just a note though, your method will work too.

Hope this helps?

CREATE FUNCTION list_to_tbl (@list nvarchar(MAX)) 
   RETURNS @tbl TABLE (string varchar(250) NOT NULL) AS 
BEGIN 
   DECLARE @pos        int, 
           @nextpos    int, 
           @valuelen   int 

   SELECT @pos = 0, @nextpos = 1 

   WHILE @nextpos > 0 
   BEGIN 
      SELECT @nextpos = charindex(',', @list, @pos + 1) 
      SELECT @valuelen = CASE WHEN @nextpos > 0 
                              THEN @nextpos 
                              ELSE len(@list) + 1 
                         END - @pos - 1 
      INSERT @tbl (string) 
         VALUES (substring(@list, @pos + 1, @valuelen))
      SELECT @pos = @nextpos 
   END 
  RETURN 
END

Open in new window

0

Featured Post

3 Use Cases for Connected Systems

Our Dev teams are like yours. They’re continually cranking out code for new features/bugs fixes, testing, deploying, testing some more, responding to production monitoring events and more. It’s complex. So, we thought you’d like to see what’s working for us.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
SSRS reports 5 31
Tracking a Database Lock - SQL 2014 10 47
SSRS Pie Chart Data Points Inside AND Outside 4 59
Best 3rd party SQL Dashboard Reporting Tool? 4 45
Written by Valentino Vranken. Introduction: The first step of creating a SQL Server Reporting Services (SSRS) report involves setting up a connection to the data source and programming a dataset to retrieve data from that data source.  The data…
Hi All, I am here to write a simple article to move SSRS (SQL Server Reporting Services) reports from one server to another. When I have faced the same issue to move reports those were developed by developer on development server and now need to …
You have products, that come in variants and want to set different prices for them? Watch this micro tutorial that describes how to configure prices for Magento super attributes. Assigning simple products to configurable: We assigned simple products…
The Email Laundry PDF encryption service allows companies to send confidential encrypted  emails to anybody. The PDF document can also contain attachments that are embedded in the encrypted PDF. The password is randomly generated by The Email Laundr…

932 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

Need Help in Real-Time?

Connect with top rated Experts

15 Experts available now in Live!

Get 1:1 Help Now