近排自己学习了一款软件finereport开发报表模块,自己总结了如何了解需求,分析需求,再进行实践应用开发,最后进行测试数据的准确性,部署报表到项目对应的模块中显示。
一、需求(根据需求文档分析)
1.条件块:
2.数据块(一部分):
3.数据取值:
数据源全部来自EAS。通过“物料收发事物汇总”查询,查询每一天的数据,填写到当天时间对应的行中。取数列为“基本数量”。
等等的仓库数据。
二、使用finereport软件进行页面模板布局
1.使用.frm的模板开发(本案例)
模板的原则就是没有数据,只是一个简单页面显示,也是方便进行下次运用数据库的方便。(简单的说,就是建楼,先建立框架先)
预览效果:
三、运用PL\SQL developer进行sql语句查询(以下截图仅仅是一部分)
1.明确数据来源那一张表、需要关联那些表、怎么关联
2.明确页面显示格式、显示的查询条件格式、数据显示格式、后台sql显示数据和页面显示数据的差别
3.明确根据页面显示的名字进行重命名(case ---when ---then----end)
4.sql查询的字段数(字段条件(多个)+数据(一个)),出现多列
四、数据部署在finereport
1.了解sql在oracle和finereport的区别
将对应的相关的语法进行分析,改其不同即可。
2.转换数据条件
实现页面上的查询条件的时间空间显示
3.效果finereport运行sql预览
4.条件过滤设计
下拉框条件显示
头条件的设计
5.导出设计和查询设计
导出:
查询:设计同上,代码如下:
var firstdate = this.options.form.getWidgetByName("firstdate").getValue();
var lastdate = this.options.form.getWidgetByName("lastdate").getValue();
if( firstdate == "" || firstdate==null){ //判断开始日期是否为空
alert("错误,开始时间不能为空"); //开始日期参数为空时提示
return false;
};
if(lastdate == "" || lastdate==null){ //判断结束日期是否为空
alert("错误,结束时间不能为空"); //结束日期参数为空时提示
return false;
};
if( firstdate > lastdate){ //判断开始日期是否大于结束日期
alert("错误,开始时间不能大于结束时间"); //开始日期大于结束日期时提示
return false;
}
//判断结束日期是否大于当前时间
var date = new Date();
var seperator1 = "-";
var seperator2 = ":";
var year = date.getFullYear();
var month = date.getMonth() + 1;
var strDate = date.getDate();
if (month >= 1 && month <= 9) {
month = "0" + month;
}
if (strDate >= 0 && strDate <= 9) {
strDate = "0" + strDate;
}
var currentdate = year + seperator1 + month + seperator1 + strDate;
if(lastdate>currentdate){
alert("结束日期不能超过当前日期!");
return false;
}
6.页面显示
五、数据校对
1.根据需求文档查询数据
2.校对官方数据与本地数据(要求原则:显示的数据全部要验证)
六、部署项目
1.创建jsp页面
2.部署页面以及报表(同步到服务器即可“SVN同步”)
3.预览效果
七、总结
从开发需求到需求实现,逻辑总的而言不是非常复杂,但在校对数据的准确性上就是相当大的工作量。正确了固然是快,但是数据有误的时候,要分析数据的错误源工作量相对巨大,因素是
错误源很多(仓库编码、物料编码、组织编码、条件属性(启动、确定、激活等)等出错、别名改错、关联出错(inner join;left join ;right join)、sql条件控制出错、finereport的条件属性出错等等)。
如果最终实现了数据在项目报表上实现,并且数据准确无误,那么你就完成这个需求的开发。我在报表的开发模块上明白,你要完成一项工作,必须要自己思考如何实现,多问几个为什么,也许你的答案就出来了,
在开发的同时也要注重开发的规范性,养好良好开发习惯,为后期维护和同事学习修改提供方便,也为自己的修改bug提供更加方便,也更加迅捷。
一句话:开发重规范,学习重思考,学习、工作、生活多总结!