SSRS Multiple Value parameter filter based on dataset

后端 未结 2 858
天涯浪人
天涯浪人 2021-01-21 15:54

Say I have a dataset in SSRS called DataSet1 that looks like this:

CREATE TABLE #data 
(ID int, Value int, UserID varchar(2))
INSERT INTO #data VALUES
(1, 1000,          


        
相关标签:
2条回答
  • 2021-01-21 16:52

    I decided to write my comment on your answer, M.Ali, as an answer to my own question, as I found a way to solve this. Maybe I didn't explain my problem precisely enough. I am aware of how the above thing works, and how to pass parameters based on one dataset, down thru the SQL to create another dataset, multiple values allowed or not. I appreciate your answer though!

    The problem I have is that the query that would define my list of values for the parameter, and the query for the actual dataset, are the same. And it's a HUGE query. In other words, where it says 'TABLE' in the code sample, I have several hundreds of lines of code. And my goal was to not have this whole query be defining both datasets. If I in the future have to change the query, I would have to do it in more than one place. Here's how I solved it:

    I placed the main query in a shared dataset instead of embedding it into my report. And I then added a row_number function to my query like so:

    SELECT ID, Value, UserID, rn = ROW_NUMBER() OVER(PARTITION BY UserID ORDER BY UserID)
    FROM *my huge query*
    

    This means that there is only one 'rn = 1' row per UserID. Then I went back to my report. My original DataSet1 would then just point to the shared dataset. The DataSet2 (the parameter one) would also point to the shared dataset with the one difference that I added a filter to that dataset saying 'rn = 1'. I then made a parameter with 'allow multiple values' that took its values from DataSet2. And it works like a charm. This way I can just go to the shared dataset when I need to update the query, and both DataSet1 and DataSet2 will be updated accordingly!

    Success :)

    Again, thanks for your answer!

    0 讨论(0)
  • 2021-01-21 16:53

    You will have to have a separate data set for your parameter query and yes you got that part right, for the given data set:

    SELECT DISTINCT UserID
    FROM TABLE
    

    This query will be used to populate the drop down list of your parameter. (Multiple values allowed or not).

    For you Main query:

    if you allow Multiple Selection for @UserID parameter you will write you main Data set query with IN operator as below:

    SELECT ID, Value, UserID
    FROM table
    WHERE (UserID IN (@UserID)) 
    

    If you only want users to be able to select only one value at a time the you can write the above query with a where clause something like WHERE UserID = @UserID.

    Make sure you map the variables correctly. But you will have to have a separate query for your drop down list.

    0 讨论(0)
提交回复
热议问题