草庐IT

关于 sql:在 SSRS 报告上显示数据,根据参数分组为周或月

codeneng 2023-03-28 原文

Show data on SSRS report grouped week or month based on parameter

我正在尝试实现在 SSRS 报告中显示的适当分组,该报告由 SSRS 中定义的 \\'weekly\\' 或 \\'monthly\\' 参数驱动(不是 sproc 的参数) .为此,我在名为 "Date" 的字段的类别组表达式中使用以下内容(格式为 \\'2014-03-01\\' 作为示例):

1
2
3
4
5
=IIF(
  Parameters!date_range.value="Weekly",
  DATEPART("week", FIELDS!DATE.Value),  
  DATEPART("month", FIELDS!DATE.Value)
)

这会导致以下异常:

The Value expression for the field ‘Date’ contains an error: Argument
'DateValue' cannot be converted to type 'Date'.
(rsRuntimeErrorInExpression). An error has occurred during report
processing. (rsProcessingAborted)

为什么?

  • 你有 dateValue 字段作为日期时间数据类型吗?您可以转换为日期时间类型并重试吗?


实现这一点的最简单方法是首先编写您的查询,该查询会向前拉出这样的结果。

SQL Server 查询

1
2
3
4
5
6
SELECT  DATEPART(MONTH, Date_Column) AS [Monthly]
       ,DATEPART(WEEK,  Date_Column) AS [Weekly]
       ,SUM(Some_Column)             AS Total
FROM TABLE_NAME
GROUP BY DATEPART(MONTH, Date_Column)
        ,DATEPART(WEEK,  Date_Column)

SSRS 报告

添加一个矩阵数据区域。将 Total 列拖放到 DATA.

创建一个Text类型的参数说GROUP ON,并提供值

1
2
1) Weekly
2) Monthly

现在在 ROW GROUPS 窗格中,右键单击唯一可见的行组并转到 GROUP PROPERTIES
GROUP ON 部分中放入以下表达式。

1
=IIF(Parameters!Groupby.Value ="Monthly", FIELDS!Monthly.Value, FIELDS!Weekly.Value)

在数据区域 ROWS 部分使用完全相同的表达式。

对于列名,您可以使用以下表达式...

1
=IIF(Parameters!Groupby.Value ="Monthly","Monthly","Weekly")

你可以走了。

重要提示

SSRS 是一个很酷的数据表示工具,但在数据操作方面并不那么酷,为了获得更好的性能,可以在更接近源(数据库、SQL Server)的地方进行各种数据操作。

所有的演示文稿都应该在 SSRS 上处理。

  • 由于我现在使用 SSRS 的经验大约是 2 周,如果我可以将您的建议应用于图表,我不会完全遵循,我的意思是看起来该解决方案实际上可以提供帮助,但我没有将 Matrix 作为表示类型?除非我错过了什么……
  • 你用的是什么图表?
  • 第一个来自 Line 类型


我建议使用 DATEPART,但我自己发现 SSRS 中的 DATEPART 并不总是像 DATEPART(SSIS 表达式)中描述的那样工作。以下是一些对我有用的具有特定语法的示例:

  • =DATEPART("yyyy", Fields!Date.Value) 年份。
  • =DATEPART(", Fields!Date.Value) 月份。
  • =DATEPART("ww", Fields!Request_Date.Value) 一周。

因此,根据@nshah 的建议将表达式转换为:

1
2
3
4
5
=IIF(
  Parameters!date_range.value="Weekly",
  DATEPART("week", format(FIELDS!DATE.Value,"yyyy-MM-dd")),  
  DATEPART("month", format(FIELDS!DATE.Value,"yyyy-MM-dd"))
)

  • 尝试了您的建议并得到与以前相同的错误
  • 难道是因为我有 3 个图表和 3 个 sproc,其中 1 个 SP 不接受 date_range 参数,但返回日期列,我强制 SSRS 按周或月。这就是我对第二张图表的意图,其中第三张图表使用实际接受@date_range 作为参数的SP(默认为在SP 中定义的"每周")?


尝试类似:

1
Format(FIELDS!DATE.Value,"yyyy-MM-dd")

这是 SQL Server 2014 吗?

链接
在 SQL Server 2014 中,DATEPART 将字符串文字隐式转换为 datetime2 类型。这意味着当日期作为字符串传递时,DATEPART 不支持格式 YDM。您必须将字符串显式转换为 datetime 或 smalldatetime 类型才能使用 YDM 格式。

有关关于 sql:在 SSRS 报告上显示数据,根据参数分组为周或月的更多相关文章

  1. ruby-on-rails - 按天对 Mongoid 对象进行分组 - 2

    在控制台中反复尝试之后,我想到了这种方法,可以按发生日期对类似activerecord的(Mongoid)对象进行分组。我不确定这是完成此任务的最佳方法,但它确实有效。有没有人有更好的建议,或者这是一个很好的方法?#eventsisanarrayofactiverecord-likeobjectsthatincludeatimeattributeevents.map{|event|#converteventsarrayintoanarrayofhasheswiththedayofthemonthandtheevent{:number=>event.time.day,:event=>ev

  2. ruby-on-rails - Rails 编辑表单不显示嵌套项 - 2

    我得到了一个包含嵌套链接的表单。编辑时链接字段为空的问题。这是我的表格:Editingkategori{:action=>'update',:id=>@konkurrancer.id})do|f|%>'Trackingurl',:style=>'width:500;'%>'Editkonkurrence'%>|我的konkurrencer模型:has_one:link我的链接模型:classLink我的konkurrancer编辑操作:defedit@konkurrancer=Konkurrancer.find(params[:id])@konkurrancer.link_attrib

  3. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  4. ruby-on-rails - 如何在 ruby​​ 中使用两个参数异步运行 exe? - 2

    exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby​​中使用两个参数异步运行exe吗?我已经尝试过ruby​​命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何ruby​​gems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除

  5. ruby - RSpec - 使用测试替身作为 block 参数 - 2

    我有一些Ruby代码,如下所示:Something.createdo|x|x.foo=barend我想编写一个测试,它使用double代替block参数x,这样我就可以调用:x_double.should_receive(:foo).with("whatever").这可能吗? 最佳答案 specify'something'dox=doublex.should_receive(:foo=).with("whatever")Something.should_receive(:create).and_yield(x)#callthere

  6. ruby - 如何在 Ruby 中拆分参数字符串 Bash 样式? - 2

    我正在为一个项目制作一个简单的shell,我希望像在Bash中一样解析参数字符串。foobar"helloworld"fooz应该变成:["foo","bar","helloworld","fooz"]等等。到目前为止,我一直在使用CSV::parse_line,将列分隔符设置为""和.compact输出。问题是我现在必须选择是要支持单引号还是双引号。CSV不支持超过一个分隔符。Python有一个名为shlex的模块:>>>shlex.split("Test'helloworld'foo")['Test','helloworld','foo']>>>shlex.split('Test"

  7. ruby - 检查方法参数的类型 - 2

    我不确定传递给方法的对象的类型是否正确。我可能会将一个字符串传递给一个只能处理整数的函数。某种运行时保证怎么样?我看不到比以下更好的选择:defsomeFixNumMangler(input)raise"wrongtype:integerrequired"unlessinput.class==FixNumother_stuffend有更好的选择吗? 最佳答案 使用Kernel#Integer在使用之前转换输入的方法。当无法以任何合理的方式将输入转换为整数时,它将引发ArgumentError。defmy_method(number)

  8. ruby-on-rails - 使用 Sublime Text 3 突出显示 HTML 背景语法中的 ERB? - 2

    所以我在关注Railscast,我注意到在html.erb文件中,ruby代码有一个微弱的背景高亮效果,以区别于其他代码HTML文档。我知道Ryan使用TextMate。我正在使用SublimeText3。我怎样才能达到同样的效果?谢谢! 最佳答案 为SublimeText安装ERB包。假设您安装了SublimeText包管理器*,只需点击cmd+shift+P即可获得命令菜单,然后键入installpackage并选择PackageControl:InstallPackage获取包管理器菜单。在该菜单中,键入ERB并在看到包时选择

  9. ruby-on-rails - 在默认方法参数中使用 .reverse_merge 或 .merge - 2

    两者都可以defsetup(options={})options.reverse_merge:size=>25,:velocity=>10end和defsetup(options={}){:size=>25,:velocity=>10}.merge(options)end在方法的参数中分配默认值。问题是:哪个更好?您更愿意使用哪一个?在性能、代码可读性或其他方面有什么不同吗?编辑:我无意中添加了bang(!)...并不是要询问nobang方法与bang方法之间的区别 最佳答案 我倾向于使用reverse_merge方法:option

  10. ruby-on-rails - link_to 不显示任何 rails - 2

    我试图在索引页中创建一个超链接,但它没有显示,也没有给出任何错误。这是我的index.html.erb代码。ListingarticlesTitleTextssss我检查了我的路线,我认为它们也没有问题。PrefixVerbURIPatternController#Actionwelcome_indexGET/welcome/index(.:format)welcome#indexarticlesGET/articles(.:format)articles#indexPOST/articles(.:format)articles#createnew_articleGET/article

随机推荐