zoukankan      html  css  js  c++  java
  • [转贴]向水晶报表传递参数

    参考--
    http://imar.spaanjaars.com/QuickDocID.aspx?QUICKDOC=310
    http://www.cddotnet.com/bbs/dispbbs.asp?boardid=3&id=3&star=1#4
    http://community.csdn.net/Expert/topic/3512/3512093.xml?temp=.3724787


    如何向 CrystalReportViewer 和 ReportDocument 传递参数……   
    一、CrystalReportViewer
    通过 CrystalReportViewer.ParameterFieldInfo 属性……
    1、CrystalReportViewer 成员
    公共实例属性
    ParameterFieldInfo(从 CrystalReportViewerbase 继承) ParameterFields。获取或设置参数字段集合。
    二、ReportDocument
    通过 ReportDocument.DataDefinition.ParameterFields 属性……
    1、ReportDocument 成员
    公共实例属性
    DataDefinition DataDefinition。获取 DataDefinition 对象。
    2、DataDefinition 成员
    公共实例属性
    ParameterFields ParameterFieldDefinitions。获取 ParameterFieldDefinitions 集合。
    三、参数字段运行时自定义(CrystalReportViewer)
    参考:
    设置参数 | Windows 窗体查看器的绑定选项 | Web 窗体查看器的绑定选项

    可支持用户在 Crystal 报表中通过参数进行输入。这种参数有多种用途。例如:
    使参数基于数据库字段并允许用户指定该字段的值,以便对报表中的数据进行筛选。
    使用参数字段将条件格式应用于报表。
    使用参数字段来定义排序顺序。
    下列示例说明如何在运行时通过代码设置参数字段值。此例解释了如何设置两个不同的参数:第一个是多值离散参数,第二个是区域值参数。

    在运行时修改参数字段

    [C#]
    // 声明将参数传递给
    //查看器控件所需的变量。
    ParameterFields paramFields = new ParameterFields ();
    ParameterField paramField = new ParameterField ();
    ParameterDiscreteValue discreteVal = new ParameterDiscreteValue ();
    ParameterRangeValue rangeVal = new ParameterRangeValue ();

    // 第一个参数是具有多个值的离散参数。

    // 设置参数字段的名称,它必须
    //和报表中的参数相符。
    paramField.ParameterFieldName = "客户姓名";

    // 设置第一个离散值并将其传递给该参数。
    discreteVal.Value = "AIC Childrens";
    paramField.CurrentValues.Add (discreteVal);

    // 设置第二个离散值并将其传递给该参数。
    // discreteVal 变量被设置为新值,这样,以前的设置
    //就不会被覆盖。
    discreteVal = new ParameterDiscreteValue ();
    discreteVal.Value = "Aruba Sport";
    paramField.CurrentValues.Add (discreteVal);

    // 将该参数添加到参数字段集合。
    paramFields.Add (paramField);

    // 第二个参数为区域值。paramField 变量
    //被设置为新值,这样,以前的设置就不会被覆盖。
    paramField = new ParameterField ();

    // 设置参数字段的名称,它必须
    //和报表中的参数相符。
    paramField.ParameterFieldName = "客户 ID";

    // 设置范围的开始值和结束值并将该范围传递给
    //该参数。
    rangeVal.StartValue = 42;
    rangeVal.EndValue = 72;
    paramField.CurrentValues.Add (rangeVal);

    // 将第二个参数添加到参数字段集合。
    paramFields.Add (paramField);

    // 将参数字段集合放入查看器控件。
    crystalReportViewer1.ParameterFieldInfo = paramFields;



    水晶报表版本9.2,后台是sqlserver 2000,该报表数据源是一个有两个参数的存储过程
    结果不管我传什么参数,报表的结果都是水晶报表开发环境中的结果.参数根本没传进去.
    请各位兄弟帮忙看看问题出在哪儿
    下面是代码
    using System;
    using System.Collections;
    using System.ComponentModel;
    using System.Data;
    using System.Drawing;
    using System.Web;
    using System.Web.SessionState;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using System.Web.UI.HtmlControls;
    using CrystalDecisions.CrystalReports.Engine;
    using CrystalDecisions.Shared;
    namespace erpreports
    {
     /// <summary>
     /// Summary description for WebForm1.
     /// </summary>
     public class WebForm1 : System.Web.UI.Page
     {
      protected CrystalDecisions.Web.CrystalReportViewer CrystalReportViewer1;
      mrb_pnper rpt;
      ParameterFields crParameterFields;
      ParameterField crParameterField;
      ParameterValues crParameterValues;
      ParameterDiscreteValue crParameterDiscreteValue;

      private void Page_Load(object sender, System.EventArgs e)
      {
       // Put user code to initialize the page here
      }

      #region Web Form Designer generated code
      override protected void OnInit(EventArgs e)
      {
       //
       // CODEGEN: This call is required by the ASP.NET Web Form Designer.
       //
       InitializeComponent();
       base.OnInit(e);
       rpt = new mrb_pnper();
       CrystalReportViewer1.ReportSource = rpt;

       //Get the collection of parameters from the report
       crParameterFields = CrystalReportViewer1.ParameterFieldInfo;

       crParameterField = crParameterFields["@begindate"];
       crParameterValues = crParameterField.CurrentValues;
       crParameterDiscreteValue = new ParameterDiscreteValue();
       crParameterDiscreteValue.Value = Request.QueryString["begindate"];
       crParameterValues.Add(crParameterDiscreteValue);

       crParameterField = crParameterFields["@enddate"];
       crParameterValues = crParameterField.CurrentValues;
       crParameterDiscreteValue = new ParameterDiscreteValue();
       crParameterDiscreteValue.Value = Request.QueryString["enddate"];
       crParameterValues.Add(crParameterDiscreteValue);
       CrystalReportViewer1.ParameterFieldInfo = crParameterFields;

      }
      
      /// <summary>
      /// Required method for Designer support - do not modify
      /// the contents of this method with the code editor.
      /// </summary>
      private void InitializeComponent()
      {   
       this.Load += new System.EventHandler(this.Page_Load);

      }
      #endregion
     }
    }


  • 相关阅读:
    云计算openstack核心组件——keystone身份认证服务(5)
    分布式存储ceph——(6)ceph 讲解
    分布式存储ceph——(5)ceph osd故障硬盘更换
    分布式存储ceph——(4)ceph 添加/删除osd
    kvm虚拟化介绍(1)
    kvm虚拟机管理(2)
    云计算openstack共享组件——Memcache 缓存系统(4)
    云计算openstack共享组件——消息队列rabbitmq(3)
    妹子UI-yepnope.js使用详解及示例分享(异步加载数据)
    前端组件整理
  • 原文地址:https://www.cnblogs.com/goody9807/p/197298.html
Copyright © 2011-2022 走看看