gpt4 book ai didi

xml - SSRS 文件错误消息 : The number of defined parameters is not equal to the number of cell definitions in the parameter panel

转载 作者:数据小太阳 更新时间:2023-10-29 02:23:21 29 4
gpt4 key购买 nike

我已使用自动化服务工具将报告文件从 Crystal (.rpt) 转换为 SSRS (.rdl)。当我在 Viusal Studio SSDT 中预览报告时,我收到一条非常奇怪的错误消息:

“定义的参数数量不等于参数面板中单元格定义的数量”

enter image description here

我也曾尝试在 Report Builder 中运行它,但我收到了同样的错误消息。

RDL文件有1710行;下面是一些看起来相关的节点的代码 -- ReportParameters、ReportLayout、QueryParameters、CommandText。

有谁知道可能导致此错误的原因是什么?我怎样才能解决它?我读过一篇文章建议隐藏参数必须有一个默认值-- SSRS the definition of the report is invalid ;在这 8 个参数中,有 7 个是隐藏的,并且没有一个具有默认参数。但我不确定默认值应该是什么(如果必须有的话)。

感谢任何帮助。

第 16..20 行

    <QueryParameters>
<QueryParameter Name=":PmPROD_WHSEPROD_CODE">
<Value>=Parameters!PmPROD_WHSEPROD_CODE.Value</Value>
</QueryParameter>
</QueryParameters>

第 1533..1573 行

  <ReportParameters>
<ReportParameter Name="PmPROD_WHSEPROD_CODE">
<DataType>String</DataType>
<Prompt>Pm-PROD_WHSE.PROD_CODE</Prompt>
</ReportParameter>
<ReportParameter Name="g_invtot">
<DataType>Float</DataType>
<Prompt>invtot</Prompt>
<Hidden>true</Hidden>
</ReportParameter>
<ReportParameter Name="g_grdtotinv">
<DataType>Float</DataType>
<Prompt>grdtotinv</Prompt>
<Hidden>true</Hidden>
</ReportParameter>
<ReportParameter Name="g_totweight">
<DataType>Float</DataType>
<Prompt>totweight</Prompt>
<Hidden>true</Hidden>
</ReportParameter>
<ReportParameter Name="g_grand_tot_wgt">
<DataType>Float</DataType>
<Prompt>grand_tot_wgt</Prompt>
<Hidden>true</Hidden>
</ReportParameter>
<ReportParameter Name="g_grdtotwgt">
<DataType>Float</DataType>
<Prompt>grdtotwgt</Prompt>
<Hidden>true</Hidden>
</ReportParameter>
<ReportParameter Name="g_totinv">
<DataType>Float</DataType>
<Prompt>totinv</Prompt>
<Hidden>true</Hidden>
</ReportParameter>
<ReportParameter Name="g_totqtyonorder">
<DataType>Float</DataType>
<Prompt>totqtyonorder</Prompt>
<Hidden>true</Hidden>
</ReportParameter>
</ReportParameters>

第 1574..1586 行

  <ReportParametersLayout>
<GridLayoutDefinition>
<NumberOfColumns>4</NumberOfColumns>
<NumberOfRows>2</NumberOfRows>
<CellDefinitions>
<CellDefinition>
<ColumnIndex>0</ColumnIndex>
<RowIndex>0</RowIndex>
<ParameterName>PmPROD_WHSEPROD_CODE</ParameterName>
</CellDefinition>
</CellDefinitions>
</GridLayoutDefinition>
</ReportParametersLayout>

第 21..55 行

<CommandText>
Select ORD_HDR.ORDER_SEQ_CODE ORD_HDR_ORDER_SEQ_CODE
, ORD_HDR.MASTER_ORDER_NBR
, ORD_HDR.STATUS_CODE
, ORD_HDR.ORDER_TYPE
, ORD_HDR.BILL_PO_ID
, ORD_HDR.SHIP_PO_ID
, ORD_HDR.SHIP_DATE
, ORD_HDR.DELIVERY_DATE
, ORD_HDR.SHIP_FROM_WHSE ORD_HDR_SHIP_FROM_WHSE
, ORD_DTL.PROD_CODE ORD_DTL_PROD_CODE
, ORD_DTL.CASES_ORD
, PRODUCT.DESCR
, Command.PRICE COMMAND_PRICE
, Command.NAME COMMAND_NAME
, Command.CITY COMMAND_CITY
, Command.STATE_CODE COMMAND_STATE_CODE
From (SELECT d.prod_code,
d.order_seq_code,
d.price + NVL (d.market_price_adj, 0) price,
h.cust_shipto_code,
c.name,
c.city,
c.state_code
FROM ord_dtl d, ord_hdr h, customer_shipto c
WHERE d.order_seq_code = h.order_seq_code
AND h.cust_code = c.cust_code
AND h.cust_shipto_code = c.cust_shipto_code) Command
INNER JOIN ROCCO.ORD_HDR ORD_HDR on (Command.ORDER_SEQ_CODE = ORD_HDR.ORDER_SEQ_CODE)
INNER JOIN ROCCO.ORD_DTL ORD_DTL on (Command.PROD_CODE = ORD_DTL.PROD_CODE and ORD_DTL.ORDER_SEQ_CODE = ORD_HDR.ORDER_SEQ_CODE)
INNER JOIN ROCCO.CUSTOMER CUSTOMER on (ORD_HDR.CUST_CODE = CUSTOMER.CUST_CODE)
INNER JOIN ROCCO.PRODUCT PRODUCT on (ORD_DTL.PROD_CODE = PRODUCT.PROD_CODE)
Where (((ORD_HDR.ORDER_TYPE &lt;&gt; 'tr') And (ORD_DTL.PROD_CODE = :PmPROD_WHSEPROD_CODE)) And (Not (ORD_HDR.STATUS_CODE in ('ED', 'dl', 'ip', 'sp')))) And (ORD_HDR.SHIP_FROM_WHSE = '06')
Order by ORD_DTL.PROD_CODE
, ORD_HDR.DELIVERY_DATE</CommandText>

最佳答案

所以事实证明,即使参数被隐藏,它仍然需要在RDL文件中有一个标签。我通过测试另一个报告来了解 RDL 文件如何使用隐藏参数来解决这个问题。

更正问题 RDL 文件...

  1. 我用文本编辑器打开它
  2. 更新了 <ReportParametersLayout><CellDefinitions> 节点包含一个 <CellDefinition> 每个参数的节点(代码如下)
  3. 保存文件
  4. 在 Visual Studio SSDT 项目中重新打开文件,然后就可以了!报告预览完成得很好。

希望这对其他人有帮助。

  <ReportParametersLayout>
<GridLayoutDefinition>
<NumberOfColumns>4</NumberOfColumns>
<NumberOfRows>2</NumberOfRows>
<CellDefinitions>
<CellDefinition>
<ColumnIndex>0</ColumnIndex>
<RowIndex>0</RowIndex>
<ParameterName>PmPROD_WHSEPROD_CODE</ParameterName>
</CellDefinition>
<CellDefinition>
<ColumnIndex>1</ColumnIndex>
<RowIndex>0</RowIndex>
<ParameterName>g_invtot</ParameterName>
</CellDefinition>
<CellDefinition>
<ColumnIndex>2</ColumnIndex>
<RowIndex>0</RowIndex>
<ParameterName>g_grdtotinv</ParameterName>
</CellDefinition>
<CellDefinition>
<ColumnIndex>3</ColumnIndex>
<RowIndex>0</RowIndex>
<ParameterName>g_totweight</ParameterName>
</CellDefinition>
<CellDefinition>
<ColumnIndex>0</ColumnIndex>
<RowIndex>1</RowIndex>
<ParameterName>g_grand_tot_wgt</ParameterName>
</CellDefinition>
<CellDefinition>
<ColumnIndex>1</ColumnIndex>
<RowIndex>1</RowIndex>
<ParameterName>g_grdtotwgt</ParameterName>
</CellDefinition>
<CellDefinition>
<ColumnIndex>2</ColumnIndex>
<RowIndex>1</RowIndex>
<ParameterName>g_totinv</ParameterName>
</CellDefinition>
<CellDefinition>
<ColumnIndex>3</ColumnIndex>
<RowIndex>1</RowIndex>
<ParameterName>g_totqtyonorder</ParameterName>
</CellDefinition>
</CellDefinitions>
</GridLayoutDefinition>
</ReportParametersLayout>

关于xml - SSRS 文件错误消息 : The number of defined parameters is not equal to the number of cell definitions in the parameter panel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51484655/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com