I can see that there are many questions already being asked regarding the same thing like:
Binding a datasource to a rdl in report server programmatically - SSRS
SSRS using Xml datasource [WCF], its possible, but is it advisable?
and many others...
But, what I really want is to have your valuable opinion before I start something and finally find myself at a dead-end !
We are developing reports in BIDS SSRS 2008 environment, VS 2010 for a Web application.
with ReportViewer 10 having ProcessingMode="Remote"
Until now, everything was ok.. passing parametetes to report, integration with asp.net etc. I mean, getting the data through SQL queries (and sometimes filtering through paramters). I could use Stored Procedures and all is working fine.
But now, there are reports which need to be generated dynamically, based on the user selection of the data from front-end, (a GridView ), on an asp.net webpage, and then display that data on the report.
That is, if a user selects 10 rows on a GridView and clicks the print button, then only those 10 rows (along with some other report specific data) should be displayed in the report. That's what we have in the legacy system, which we are upgrading now.
and of course, this cannot be achieved merely through passing the parameters, because selection of data on the GridView depends all on the user, and is all dynamic. .. there I am in a fix now!
So, what can be the best approach for these kinds of situations?
P.S (Edit): there are solutions out there but they are more pertaining to .rdlc , and I am talking about .rdl
Most likely, you may wind up needing to run them in the context of the web application, and pull the data from the datasource into the report by hand.
I did this project a few years ago, and wouldn't mind getting it back up and running, and finally completed to support MVC/Web Forms/Win Forms/WPF/etc. as well as get it more robust.
This may get you on the right track.
Finally we implemented it like the following . I thought may be it is of some use to others. So am posting my solution:
This can be done with the implementation of XML
First convert your data into XML, like following:
You need to replace
((object[])(item.DataItem))[].ToString()
with your own valuesThen generate your report like following :
You should add a Parameter
"list"
to your report. because we will be passing whole XML thing to this"list"
through the following Dataset,Now the Dataset that will handle this XML:
Normally, what we do is you write some stored procedure or write some query inside the dataset, since ours is the XML, it needs to be handled XML way,
With the
Query Type: Text
write the following query to handle the XML dataThe Fields
NAME
,CONTACT
etc. should be the same with what you created the XML document in the first place, at the topConvertToXML
So the bottom line is, you are not passing data to report through strored procedure from DB but you are actaully grabbing data from aspx page - Code behind and converting the same to XML and passing it to your report-server report via this Dataset
So whats in the code behind is passed to your report.. voila !