C#中把FastReport.Net报表控件的数据保存到数据库

 更新时间:2022年06月07日 16:06:51   作者:Elyn  
这篇文章介绍了在数据库中保存FastReport.Net报表的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

通常报表都存储在一个地方,但是在单独的文件中。随着文件数量的增加在结构和搜索上也困难多多,针对这个问题,我遇到了一个非常有趣的报表对象属性——ReportSourceString,此属性以字符串形式保存整个报表模板。
这意味着它可以在任何数据库中存储报表模板,并把所有的报表都存储在一个地方。为了将报表保存到数据库中,我们需要编写自己的方法来保存和加载报表。下面就开始吧!
首先,让我们创建一个数据库来存储报表。我已经使用了微软的访问。该表的结构如下:

创建窗体应用程序。添加连接到数据库。放置按钮组件到表单:数据集,BindingSource和报表。

我们需要一个对话框,在保存/加载时会要求报表的名称:

按钮必须根据名称来设置DialogResult属性。
开始设计,我们使用下面的fastreports库:

using FastReport;
using FastReport.Utils;
using FastReport.Design;

创建实例对话框:

public SaveLoadForm form2 = new SaveLoadForm();

创建事件处理程序来保存报表:

void cmdSave_CustomAction(object sender, EventArgs e)
{
    ReportsDataSet.ReportsRow row;
    row = reportsDataSet1.Reports.NewReportsRow();
    if (form2.ShowDialog() == DialogResult.OK)
    {
        row.Name = form2.ReportName;
        row.Template = report1.ReportResourceString;
        this.reportsDataSet1.Reports.Rows.Add(row);
        ReportsDataSetTableAdapters.ReportsTableAdapter adapter = new ReportsDataSetTableAdapters.ReportsTableAdapter();
        adapter.Update(reportsDataSet1.Reports);
    }
}

这里,我们在报表表单中创建一个新的行,紧接着开始对话框。将报表名称输入表单,分配对话框的文本字段值到名称字段,在模板字段中将报表模板写入文本。此后,通过适配器将更改的内容保存到表中。
现在创建一个报表下载的事件处理程序:

void cmdOpen_CustomAction(object sender, EventArgs e)
{
    if (form2.ShowDialog() == DialogResult.OK)
    {
        for (int i = 1; i < reportsDataSet1.Reports.Rows.Count; i++)
        if (reportsDataSet1.Reports[i].Name == form2.ReportName)
        {
            report1.ReportResourceString = reportsDataSet1.Reports[i].Template.ToString();
        }
        Designer designer = sender as Designer;
        designer.SetModified(this, "EditData");
    }
}

调用对话框,在循环中查找与在文本字段中输入的名称相对应的报表,从模板字段中加载报表到ReportResourceString属性。然后,设计师根据改变做出更新。
所以,我们写了2个处理程序。它是必要的,以拦截标准的事件处理程序并用我们的处理程序替代。

private void DesignerSettings_DesignerLoaded(object sender, EventArgs e)
{
    (sender as Designer).cmdSaveAs.CustomAction += new EventHandler(cmdSave_CustomAction);
    (sender as Designer).cmdOpen.CustomAction += new EventHandler(cmdOpen_CustomAction);
}

正如你所看到那样,我们通过自定义处理程序拦截事件来保存和加载一个报表。
在主表单中按钮OnClick事件中添加以下代码:

private void DesignBtn_Click(object sender, EventArgs e)
{
    Config.DesignerSettings.DesignerLoaded += DesignerSettings_DesignerLoaded;
    report1.Design();
}

重写处理程序加载报表设计器。
这样,我们就已经创建了一个应用程序,允许您在MS访问数据库中保存和加载报表。您可以通过ReportSourceString报表属性在自己希望的数据库中组织报表的存储。

到此这篇关于在数据库中保存FastReport.Net报表的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C#实现装饰器模式

    C#实现装饰器模式

    这篇文章介绍了C#实现装饰器模式的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07
  • C# 使用EntityFramework CodeFirst 创建PostgreSQL数据库的详细过程

    C# 使用EntityFramework CodeFirst 创建PostgreSQL数据库的详细过程

    这篇文章主要介绍了C#使用EntityFramework CodeFirst创建PostgreSQL数据库的过程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-07-07
  • c# 如何用lock解决缓存击穿

    c# 如何用lock解决缓存击穿

    这篇文章主要介绍了c# 如何用lock解决缓存击穿,帮助大家更好的理解和使用c#,感兴趣的朋友可以了解下
    2021-02-02
  • C#处理猜拳问题的简单实例(非窗体)

    C#处理猜拳问题的简单实例(非窗体)

    下面小编就为大家带来一篇C#处理猜拳问题的简单实例(非窗体)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-07-07
  • C#中创建PDF网格并插入图片的方法

    C#中创建PDF网格并插入图片的方法

    这篇文章我将向大家演示如何以编程的方式在PDF文档中创建一个网格,并将图片插入特定的网格中。对c# pdf 网格 插入图片的知识感兴趣的朋友一起看看吧
    2016-11-11
  • C#实现可缓存网页到本地的反向代理工具实例

    C#实现可缓存网页到本地的反向代理工具实例

    这篇文章主要介绍了C#实现可缓存网页到本地的反向代理工具,实例分析了C#实现反向代理的相关技巧,非常具有实用价值,需要的朋友可以参考下
    2015-04-04
  • c# 递归访问文件夹(删掉歌词文件)

    c# 递归访问文件夹(删掉歌词文件)

    今天想把我的音乐里面500首的mp3都拷到手机里,不过这些mp3都有很多层目录,而且每首歌曲都还有歌词文件,我只想留下mp3,歌词文件都删掉,就写了个小程序跑一下,比手动删快多了
    2012-06-06
  • C#、ASP.NET通用工具类IsWhat?(可以判断数字、身份证、数据类型等等)

    C#、ASP.NET通用工具类IsWhat?(可以判断数字、身份证、数据类型等等)

    这篇文章主要介绍了C#、ASP.NET通用工具类IsWhat?(可以判断数字、身份证、数据类型等等),本文收集整理了多个扩展函数,简单实用,项目必备,如值范围、在里面吗、是null或""?、是零?等等,需要的朋友可以参考下
    2015-06-06
  • Unity实现主角移动与摄像机跟随

    Unity实现主角移动与摄像机跟随

    这篇文章主要为大家详细介绍了Unity实现主角移动与摄像机跟随,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-03-03
  • WPF实现Badge标识的示例代码

    WPF实现Badge标识的示例代码

    这篇文章主要为大家详细介绍了WPF如何实现Badge标识,文中的示例代码讲解详细,对我们学习或工作有一定帮助,感兴趣的小伙伴可以了解一下
    2023-06-06

最新评论