Using Fields in Multiple Datasets in SSRS

后端 未结 3 1462
孤独总比滥情好
孤独总比滥情好 2021-01-04 21:35

I understand Crystal Reports has fallen out of favor with some in the development community and perhaps rightly so: I haven\'t used it in about 15 years. But when I did, I c

相关标签:
3条回答
  • 2021-01-04 21:48

    Neither Crystal nor SSRS will allow you to directly compare values in two different datasets on a row-by-row basis.

    In both tools:

    • If both datasets come from the same relational database, then the simplest way to compare values is to combine the two datasets into a single query.
    • If both datasets come from different relational databases that can be linked together (for example, by using Linked Servers in SQLServer, or Database Links in Oracle), then the simplest way to compare values is to combine the two datasets into a single query that accesses both linked databases.
    • If both datasets come from datasources that cannot be directly linked together, then the two datasets can be linked together in Crystal/SSRS by means of a subreport. (More details on subreports in SSRS here.)

    There is a reporting tool called BIRT that has a similar reporting paradigm to SSRS (ie. a web-style layout, instead of Crystal's banded reporting approach), includes much the same functionality as SSRS, is Open Source and enables you to link datasets together directly to create joint datasets. However, it is less intuitive to use than either Crystal or SSRS.

    0 讨论(0)
  • 2021-01-04 21:51

    Stick with it - Reporting Services is an amazingly flexible reporting platform.

    You can do what you want by specifying the dataset after the field name but you have to specify which Foo2 you want or how you want to deal with Foo2.

    The way you do this is through aggregate functions. For example, lets say Dataset2 only has one row of data, then you get the first one:

    =Fields!Foo1.Value / First(Fields!Foo2.Value, "Dataset2")
    

    If there are many rows and you want to divide by the sum of Foo2 then you can do this:

    =Fields!Foo1.Value / Sum(Fields!Foo2.Value, "Dataset2")
    

    The point is, you are currently stepping through Dataset1 - you need to let Reporting Services know how to deal with Dataset2 in order to return the Foo2 you need.

    0 讨论(0)
  • 2021-01-04 21:58

    I think your would have been resolved by now, however if u r facing same issue then you can use lookup in expression.
    It enable you to browse through values of other dataset while there is a common field in both the datasets

    =Lookup(value in dataset1,value in dataset2, common field in both datasets, dataset name from which we need to get data)
    
    0 讨论(0)
提交回复
热议问题