为SectionReport添加排序功能

ActiveReports 7中提供了两种报表类型SectionReport和PageReport,在PageReport中提供了Table等控件可以非常方便地对报表中数据进行排序操作,不过在SectionReport中没有提供这种支持排序的控件,下面我们就来看看在SectionReport中如何实现数据的排序操作。

发布于 2012/11/15 00:00

ActiveReports 7中提供了两种报表类型SectionReport和PageReport,在PageReport中提供了Table等控件可以非常方便地对报表中数据进行排序操作,不过在SectionReport中没有提供这种支持排序的控件,下面我们就来看看在SectionReport中如何实现数据的排序操作。

在SectionReport中实现数据排序,主要是借助TextBox的HyperLink属性,以及Viewer控件的HyperLink事件。

首先创建我们需要的报表,在VS中添加新项目,选择【ActiveReports 7 Section Report(code-based)】


然后添加报表ReportStart事件的处理逻辑:

 
private void SectionReport1_ReportStart(object sender, EventArgs e)
    {
        OleDBDataSource ds = new OleDBDataSource();
        ds.ConnectionString = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=App_Data\\Reels.mdb;Persist Security Info=False";
        ds.SQL = "SELECT * FROM Product order by " + Column + " " + Sort;
        ((TextBox)pageHeader.Controls["txt" + Column + "Sort"]).Text = (Sort == "Asc") ? "▲" : "▼";
        ((TextBox)pageHeader.Controls["txt" + Column + "Sort"]).HyperLink = Column + ":" + Sort;
        this.DataSource = ds;
    }
复制代码

在Form1上添加ActiveReports 7的报表浏览控件Viewer,并添加Viewer的HyperLink事件处理逻辑:

 
private void viewer1_HyperLink(object sender, GrapeCity.ActiveReports.Viewer.Win.HyperLinkEventArgs e)
    {
        SectionReport1 rpt = new SectionReport1();
        rpt.Column = e.HyperLink.Split(':')[0];
        rpt.Sort = (e.HyperLink.Split(':')[1] == "Asc") ? "Desc" : "Asc";
        rpt.Run();
        viewer1.LoadDocument(rpt.Document);
    }
复制代码

运行程序,点击各列中的排序按钮:


源码下载:VS2010 + ActiveReports 7

关于葡萄城

葡萄城是专业的软件开发技术和低代码平台提供商,以“赋能开发者”为使命,致力于通过表格控件、低代码和BI等各类软件开发工具和服务,一站式满足开发者需求,帮助企业提升开发效率并创新开发模式。葡萄城开发技术始于1980年,40余年来始终聚焦软件开发技术,有深厚的技术积累和丰富的产品线。是业界能够同时赋能软件开发和低代码开发的企业。凭借过硬的产品能力、活跃的用户社区和丰富的伙伴生态,与超过3000家合作伙伴紧密合作,产品广泛应用于信息和软件服务、制造、交通运输、建筑、金融、能源、教育、公共管理等支柱产业。

推荐相关案例
推荐相关资源
关注微信
葡萄城社区二维码

关注“葡萄城社区”

加微信获取技术资讯

加微信获取技术资讯

想了解更多信息,请联系我们, 随时掌握技术资源和产品动态