回顾与说明

前面我们把“商品字典”、“商品入库”、“商品库存查询”三个模块已经概括或者详细的演示完了,这些模块涉及到简单数据的增、删、修,也涉及到复杂业务处理的事务、业务层提取,以及MIS系统中非常常见的查询、报表打印技术和基础字典的缓存查询技术。

本文内容

今天我们将以另外一种技术实现另一个模块“商品入库查询”,将采用何种技术呢,其实也是一个很简单的技术,在构建UI应用中使用报表技术,即我们把打印预览的报表技术使用在业务查询应用的主体UI之中,如下图所示一样的效果:

制做界面

首先,我们需要在UI项目中增加一个WinForm窗体ProductInQueryForm拖动控件达到如下效果:
在这里,我们需要注意的是需要向界面放一个报表预览控件,报表预览控件由EAS.Report.Controls程序集承载,类型EAS.Report.Controls.RDLReportViewer,打印预览控件工具条显示位置由属性ToolBoxDockStyle决定,我们设置为DockStyle.Bottom。

处理查询

接下来我们编写查询相关的代码,先在数据层接口项目中的IProductInList的分部类定义IProductInList.cs文件中增加如下代码:
 1:  /// <summary>
 2:  /// 表接口 IProductInList(产品入库)。
 3:  /// </summary>
 4:  public partial interface IProductInList
 5:  {
 6:      /// <summary>
 7:      /// 根据入库票据号查询入库明细。
 8:      /// </summary>
 9:      /// <param name="billCode">入库票据号。</param>
10:      void GetProductInList(string billCode);
11:   
12:      /// <summary>
13:      /// 根据入库时间及拼音简码查询入库明细。
14:      /// </summary>
15:      /// <param name="startTime">开始时间。</param>
16:      /// <param name="endTime">结束时间。</param>
17:      /// <param name="pyCode">拼音简码。</param>
18:      void GetProductInList(DateTime startTime,DateTime endTime,string pyCode);
19:  }

同样,我们需要在数据层实现项目中实现这个方法:
 1:  public void GetProductInList(DateTime startTime, DateTime endTime, string pyCode)
 2:  {
 3:      Condition condition = this.CreateCondition();
 4:   
 5:      if (!startTime.Equals(endTime))
 6:      {
 7:          List<DateTime> times = new List<DateTime>(2);
 8:          times.Add(startTime);
 9:          times.Add(endTime);
10:   
11:          condition.AddElement("InTime", times, ElementType.BetWeen);
12:      }
13:   
14:      if (pyCode.Length > 0)
15:          condition.AddElement("SqlText", "CODE in (select CODE from dbo.PRODUCT where PYCODE like '" + pyCode + "%')", ElementType.SqlCondition);
16:   
17:      this.Query(condition);
18:  }

大家在这地方仔细看一下,因为在商品库存表中没有定义产品的拼音简码,所以我就使用了一个字查询,并以SQL条件的形式写了出来,在实现应用中,应该在产品库存表中增加拼音简码字典,以方便查询。

制作报表

这一步在前面的文章中已经有过详细的介绍了,在这就简单的走过,打开报表设计器,选择对象报表,数据对象为Product.DAL.SQLServer.ProductInList,我们做出如下样式的报表:
需要注意的是,在这个报表中,我增加了一个分组,按单据号进行分组并显示分组统计,完成报表设计之后,保存在编译目标目录中的Reports文件夹中并取名为“商品入库查询报表.rdl”。

集成代码

接下来我们修改程序,把报表挂载进来,编写“查询”按钮的事件处理代码:
 1:  private void btnSearch_Click(object sender, EventArgs e)
 2:  {
 3:      //加载报表
 4:  
 5:      if (this.reportViewer.SourceRdl==null)
 6:      {
 7:          System.IO.TextReader textReader = null;
 8:          try
 9:          {
10:              string fileName = Path.Combine(Application.StartupPath, "Reports\\商品入库查询报表.rdl");
11:              textReader = new System.IO.StreamReader(fileName);
12:              this.reportViewer.SourceRdl = textReader.ReadToEnd();
13:          }
14:          finally
15:          {
16:              if (textReader != null)
17:                  textReader.Close();
18:          }
19:      }
20:   
21:      //处理数据
22:      IProductInList table = DALHelper.DALManager.CreateProductInList();
23:      table.GetProductInList(this.dtpStartTime.Value,this.dtpEndTime.Value, this.tbSearch.Text);
24:      this.reportViewer.DataObject = table;
25:  }        

运行结果
    编译并运行程序,我们看一下运行效果:

打印预览:

我们把报表导出来,选择导出Excel格式:
这里我们需要注意的是:导出Excel格式只支持Excel2007格式,这个让我很纠结,我不喜欢装备庞大的office2007,2010更是用一个月就用不成了,挺郁闷的,Wps自带的表格软件打不开这个格式。
至此,“商品入库查询”模块的相关处理就此结束,接下来我将介绍“商品字典”的另一个实现,同时演示ORM对象与DataGridView的绑定技术,希望大家感兴趣,对AgileEAS.NET平台感兴趣的朋友呢,可以下载了完整代码之后自己看看,有问题请及时的和我联系。
有关本例所涉及的数据表结构请参考基于AgileEAS.NET平台基础类库进行应用开发-总体说明及数据定义一文,有关数据对象模型定义文件、文档、DDL脚本请下载:http://files.cnblogs.com/eastjade/demo.db.doc.sql.rar,本例完整代码下载:Product.Demo.rar。

链接

一步一步教你使用AgileEAS.NET基础类库进行应用开发-系列目录
AgileEAS.NET平台开发指南-系列目录
AgileEAS.NET应用开发平台介绍-文章索引
AgileEAS.NET平台应用开发教程-案例计划
AgileEAS.NET官方网站
敏捷软件工程实验室
QQ群:116773358

转载于:https://blog.51cto.com/agilelab/603071

一步一步教你使用AgileEAS.NET基础类库进行应用开发-WinForm应用篇-演示使用报表构建UI-入库业务查询模块...相关推荐

  1. 一步一步教你使用AgileEAS.NET基础类库进行应用开发-WinForm应用篇-实现字典的打印...

    系列回顾 从上一篇文章一步一步教你使用AgileEAS.NET基础类库进行应用开发-WinForm应用篇-实例一个模块(商品字典)开始我带领大家进入WinForm篇,并且使用示例的形式详细的演示了数据 ...

  2. 一步一步教你使用AgileEAS.NET基础类库进行应用开发-WinForm应用篇-在UI中应用DataUIMapper组件...

    系列回顾 WinForm篇我用了一步一步教你使用AgileEAS.NET基础类库进行应用开发-WinForm应用篇-实例一个模块(商品字典)和一步一步教你使用AgileEAS.NET基础类库进行应用开 ...

  3. 一步一步教你使用AgileEAS.NET基础类库进行应用开发-系列目录

    基实这个系统是我AgileEAS.NET平台应用开发教程-案例计划的详细分解,原来想着按前面文章的思路应用写,但是发布之前的想法有点乱,我就把他分解成两个系列,使用step-by-step的方式来降解 ...

  4. 一步一步教你使用AgileEAS.NET基础类库进行应用开发-基础篇-基于接口驱动的数据层...

    系列回顾 在前面的文章中,我用了大量的篇幅对UDA及ORM的使用进行了讲解和演示,我们已经知道并熟悉的使用UDA和ORM构建简单的应用,AgileEAS.NET在应用的纵向结构上建议使用分层结构,提出 ...

  5. 一步一步教你使用AgileEAS.NET基础类库进行应用开发-基础篇-通过SQL实现特殊业务...

    前面的四篇文章演示ORM的一些常规操作与配置,通过前面的文章,应用开发人员要可以使用ORM开发出简单的应用,但是,ORM也不是万能钥匙,在业务应用中,还有很多是ORM解决不了的问题,对于这些问题,我们 ...

  6. 一步一步教你使用AgileEAS.NET基础类库进行应用开发-基础篇-演示ORM中的查询

    前文回顾 前面的文章一步一步教你使用AgileEAS.NET基础类库进行应用开发-基础篇-演示ORM的基本操作一文给大家介绍了如果使用ORM实现数据的读取.插入.更新与删除基本业务也讲解了ORM开发基 ...

  7. 一步一步教你使用AgileEAS.NET基础类库进行应用开发-基础篇-使用UDA操纵SQL语句...

    上一篇文章基于AgileEAS.NET平台基础类库进行应用开发-总体说明及数据定义中对本案例所涉及的数据表及部分数据,本文开始将从最基本的业务,数据访问--SQL语句操纵开始. 在AgileEAS.N ...

  8. 通过脚本案例学习shell(五) 通过创建DNS脚本一步一步教你将一个普通脚本规范到一个生产环境脚本...

    通过脚本案例学习shell(五) 通过创建DNS脚本一步一步教你将一个普通脚本规范到一个生产环境脚本   版权声明: 本文遵循"署名非商业性使用相同方式共享 2.5 中国大陆"协议 ...

  9. 教你一步一步用C语言实现sift算法、上

    原文:http://blog.csdn.net/v_july_v/article/details/6245939 引言:     在我写的关于sift算法的前倆篇文章里头,已经对sift算法有了初步的 ...

最新文章

  1. adoquery查询结果如何赋给一个变量(delphi和c++ builder)
  2. AI一分钟|传谷歌正与腾讯等洽谈合作,欲在中国推云服务;国产超算运算速度或达每秒百亿亿次...
  3. 参加第二届中国网络营销行业大会会议记录
  4. python有道翻译接口-Python通过调用有道翻译api实现翻译功能示例
  5. 在featureDataset和workspace下創建featureclass
  6. 指令级别解释对象创建过程和DCL为什么要volatile
  7. Unity3D 游戏引擎之平面小球重力感应详解【转】
  8. CentOS7 源码编译安装Redis shell脚本
  9. mysql 优化配置参数(my.cnf)
  10. 高8kB计算机组成原理,计算机组成原理习题及答案
  11. teigha开发从入门到精通(3)-- 编译drawings sdk示例
  12. 亮晶晶幼儿园家校沟通平台的设计与实现
  13. 如何在VScode中配置python第三方库
  14. java excel转pdf 的实现_JAVA语言实现excel转pdf文件
  15. jeston nano bo1卡槽坏了,不能锁住tf卡,维修方法
  16. 抖音上热门的好处有哪些?
  17. 1189 SEARCH
  18. 项目管理之产品交付1
  19. c# - 作业4:中国象棋
  20. 聊聊云原生数据库的一致性

热门文章

  1. python卷子_Python试卷
  2. python 安卓模拟器电脑版_【夜神安卓模拟器电脑版】夜神安卓模拟器电脑版 V6.6.0.6免费版官方免费下载_正式版下载-多特软件站...
  3. 在苹果笔记本如何使用python_mac下如何将python2.7改为python3
  4. mysql php 变量赋值,在MySQL UPDATE(PHP / MySQL)中使用变量
  5. mysql 主从_搭建mysql主从并编写监控主从状态脚本
  6. 计算机网络系统系统设备配置,计算机网络系统技术方案及设备配置方案
  7. java中final关键字、权限修饰符、内部类(成员内部类、局部内部类、匿名内部类)
  8. 互联网晚报 | 11月27日 星期六 | 电子烟等新型烟草制品参照卷烟监管;有赞上线“有赞酒店”;法拉第未来收到退市通知...
  9. 中国移动互联网流量半年度分析报告
  10. python3 json_Python3 解析复杂结构的 json