VB查询数据库之报表——机房收费系统总结(六)
我们要用一个软件做报表的模板、然后在VB里面添加部件、代码调用模板,详细步骤如下。
一、下载安装
首先做报表要下载安装Grid++Report 4.5 报表设计器
点击下载(内含破解补丁)
二、制作模板
1、打开软件——插入——页眉、明细网格、页脚、如图
2。制作页眉
静态框:好像Label,能写入文字并显示
综合文字框:可以写入函数、变量等、跟文字结合并显示、在这里我们用作显示日期
上图右下角[#date3#][#time#]制作是自定义了date3跟time这两个变量、并且在VB代码中付给他俩当前的日期与时间、做法如下。
(1)新建参数
这里叫做参数、其实也是数据的容器、我还是习惯叫变量、都差不多
在软件的右边如图、参数集合---插入---参数
(2)更改属性
这个就是相当于给参数或者说变量命名、定义格式、定义数据类型
名称:VB付给这个参数值的时候要写
格式:日期是yyyy/mm/dd时间的是hh:mm:ss如图
我一共定义了4个参数、
date1和date2是显示周报表查询从日期1到日期2的日期如图
date3和time是显示当前日期和时间
具体效果如图
(3)放到页眉上
参数定义好、下面就放上去了、首先在页眉新建一个综合文字框
然后双击文字框、弹出窗口点击、插入域-----引用类型选参数----然后选择参数
效果如图
3、制作表格
(1)连接数据库(从左到右依次点击)
——查询的SQL语句写自己的表
记得点下测试、一般没问题、有问题的话看下SQL语句是否写错
(2)生成字段和列
先点击1、然后点击2、便可以自动执行刚刚的SQL语句获得表里的字段和行
页眉就不说了、直接用静态框就可以了
1.添加Grid++Report 的控件、如图
2.选择名字为GRDisplayViewer的控件、放到From上(蓝色第一个)
3.其他控件也放上去、名字如下图(跟我名字一样才能用.名字不一样要改代码)
4.开始时间和结束时间用的是时间控件DTPicter时间控件,部件载入名上图有(本人忘了是哪个了……)
5.引用(菜单--工程--引用)引用Grid++Re…………如图
6.代码(复制进去应该就行了、有详细备注、实在不懂的可以点我)
[vb] view plaincopyprint?
1.Dim WithEvents Report As grproLibCtl.GridppReport '实例化报表</SPAN>
2.'报表刷新
3.Private Sub cmdCheckDay_Click()
4. Dim txtsql As String
5. '判定终止日期不能小于起始日期
6. If StartDateView.Value > EndDateView.Value Then '条件限制
7. MsgBox "终止日期不能小于起始日期!", ,"温馨提示"
8. Exit Sub
9. End If
10.
11. Report.DetailGrid.Recordset.ConnectionString = ConnectString '数据源连接数据库直接调用写好的模块内容
12. If txtBalance.Text = "" Then '判断上期text里是否为空
13. '查询日期1到日期2的记录
14. txtsql = "select * from ReportForms_Info where cast(convert(varchar,date) as datetime) between '" & _
15. StartDateView.Value & "' and '" & EndDateView.Value & "'"
16. Else
17. '如果上期余额的text里不为空则查询日期1到日期2中、上期余额是文本中的记录
18. txtsql = "select * from ReportForms_Info where cast(convert(varchar,date) as datetime) between '" & _
19. StartDateView.Value & "' and '" _
20. & EndDateView.Value & "' And Balance = '" & txtBalance.Text & "'"
21. End If
22.
23. '显示报表中的内容
24. Report.DetailGrid.Recordset.QuerySQL = txtsql
25. grdWeekliyBill.Refresh
26.
27. '报表模板上的4个日期或时间赋值
28. Report.ParameterByName("Date1").Value = Format$(StartDateView.Value, "yyyy-mm-dd")
29. Report.ParameterByName("Date2").Value = Format$(EndDateView.Value, "yyyy-mm-dd")
30. Report.ParameterByName("Date3").Value = Date
31. Report.ParameterByName("time").Value = Time
32.
33.End Sub
34.'预览
35.Private Sub cmdpreview_Click()
36. Report.PrintPreview (True)
37.End Sub
38.
39.'打印
40.Private Sub cmdput_Click()
41. Report.[Print] (True)
42.End Sub
43.
44.'载入窗体
45.Private Sub Form_Load()
46. '创建报表对象
47. Set Report = New grproLibCtl.GridppReport
48. '载入报表模版文件
49. Report.LoadFromFile (App.Path & "\周报表.grf")
50. '设置数据连接串
51. Report.DetailGrid.Recordset.ConnectionString = ConnectString
52.
53. '查询语句
54. txtsql = "select * from ReportForms_Info where cast(convert(varchar,date) as datetime) between '" & StartDateView.Value & "' and '" & EndDateView.Value & "'"
55. Report.DetailGrid.Recordset.QuerySQL = txtsql '执行
56. '显示报表中的内容
57. grdWeekliyBill.Report = Report
58. grdWeekliyBill.Start
59.
60. '报表模板上的4个日期或时间赋值
61. Report.ParameterByName("Date1").Value = Format$(StartDateView.Value, "yyyy-mm-dd")
62. Report.ParameterByName("Date2").Value = Format$(EndDateView.Value, "yyyy-mm-dd")
63. Report.ParameterByName("Date3").Value = Date
64. Report.ParameterByName("time").Value = Time
65.
66.End Sub
Dim WithEvents Report As grproLibCtl.GridppReport '实例化报表</SPAN>
'报表刷新
Private Sub cmdCheckDay_Click()
Dim txtsql As String
'判定终止日期不能小于起始日期
If StartDateView.Value > EndDateView.Value Then '条件限制
MsgBox "终止日期不能小于起始日期!", ,"温馨提示"
Exit Sub
End If Report.DetailGrid.Recordset.ConnectionString = ConnectString '数据源连接数据库直接调用写好的模块内容
If txtBalance.Text = "" Then '判断上期text里是否为空
'查询日期1到日期2的记录
txtsql = "select * from ReportForms_Info where cast(convert(varchar,date) as datetime) between '" & _
StartDateView.Value & "' and '" & EndDateView.Value & "'"
Else
'如果上期余额的text里不为空则查询日期1到日期2中、上期余额是文本中的记录
txtsql = "select * from ReportForms_Info where cast(convert(varchar,date) as datetime) between '" & _
StartDateView.Value & "' and '" _
& EndDateView.Value & "' And Balance = '" & txtBalance.Text & "'"
End If '显示报表中的内容
Report.DetailGrid.Recordset.QuerySQL = txtsql
grdWeekliyBill.Refresh '报表模板上的4个日期或时间赋值
Report.ParameterByName("Date1").Value = Format$(StartDateView.Value, "yyyy-mm-dd")
Report.ParameterByName("Date2").Value = Format$(EndDateView.Value, "yyyy-mm-dd")
Report.ParameterByName("Date3").Value = Date
Report.ParameterByName("time").Value = Time End Sub
'预览
Private Sub cmdpreview_Click()
Report.PrintPreview (True)
End Sub '打印
Private Sub cmdput_Click()
Report.[Print] (True)
End Sub '载入窗体
Private Sub Form_Load()
'创建报表对象
Set Report = New grproLibCtl.GridppReport
'载入报表模版文件
Report.LoadFromFile (App.Path & "\周报表.grf")
'设置数据连接串
Report.DetailGrid.Recordset.ConnectionString = ConnectString '查询语句
txtsql = "select * from ReportForms_Info where cast(convert(varchar,date) as datetime) between '" & StartDateView.Value & "' and '" & EndDateView.Value & "'"
Report.DetailGrid.Recordset.QuerySQL = txtsql '执行
'显示报表中的内容
grdWeekliyBill.Report = Report
grdWeekliyBill.Start '报表模板上的4个日期或时间赋值
Report.ParameterByName("Date1").Value = Format$(StartDateView.Value, "yyyy-mm-dd")
Report.ParameterByName("Date2").Value = Format$(EndDateView.Value, "yyyy-mm-dd")
Report.ParameterByName("Date3").Value = Date
Report.ParameterByName("time").Value = Time End Sub
版权声明:本文为博主原创文章,未经博主允许不得转载。
VB查询数据库之报表——机房收费系统总结(六)的更多相关文章
- VB查询数据库之结账——机房收费系统总结(五)
对于机房收费的结账,我感觉是所有窗体中,最难的一个.这个窗体我真的做了好多天.它的难度系数我感觉是最高的. 首先,你要理清上机时间和收费标准的关系,在预备时间中,是不收费的. 其次,在超过预备时间,一 ...
- VB查询数据库之终极篇——机房收费系统总结(七)
机房收费系统总结系列到此就算是要结束了.在做机房收费系统之前,做了学生管理系统,可以说,对机房收费系统的帮助很大. 在机房收费系统中,数据库的查询,数据写入数据库,更改数据库内的信息等一些操作在学生信 ...
- VB查询数据库之写入数据库——机房收费系统总结(三)
在机房收费系统中,新注册的用户,更改的密码,上机下级记录,上机收费记录等等都要写入数据库,这样,后面的查询才能生效.像数据库中写入数据,首先,找到你要写入数据的数据库中的表,在表中建立新的行,让后再把 ...
- VB.NET版机房收费系统---报表
报表,即报告情况的表格,简单的说:报表就是用表格.图表等格式来动态显示数据,可以用公式表示为:"报表 = 多样的格式 + 动态的数据". 在没有计算机以前,人们利用纸和笔来记录数据 ...
- VB查询数据库之登陆窗体——机房收费总结(一)
机房收费系统已经做了很长一段时间了,虽然到目前为止,仍然没有结束,但已经结节尾声了.我感觉现在有必要回首总结一下整个机房收费系统. 除了结账做了一半,报表接触一点之外,其他的都基本上差不多了.从做过的 ...
- 机房收费系统(VB.NET)——超具体的报表制作过程
之前做机房收费系统用的报表是Grid++Report,这次VB.NET重构中用到了VisualStudio自带的报表控件. 刚開始当然对这块功能非常不熟悉,只是探究了一段时间后还是把它做出来了. 以下 ...
- 机房收费系统之vb报表的模板的制作(一)
机房收费系统有报表的功能,报表对于我们来说有点陌生.这不是会计的事吗?怎么机房收费系统也參合进来了,事实上我们学会了报表的步骤.理解了代码后.报表变得不是非常难,世上无难事,仅仅怕肯登攀 ...
- VB查询数据库之组合查询——机房收费总结(二)
在机房收费系统中,组合查询用的还是挺多的,像上机状态查询窗体.学生上机统计信息窗体.操作员工记录窗体.基本信息维护窗体.这其中,学生基本信息维护窗体中的东西比较多,就以它为例子,说说组合查询吧! 学生 ...
- 机房收费系统——技术总结 标签: vb数据库技术 2014-09-07 22:29 1153人阅读 评论(30)
说完了经验,再谈谈技术方面,其实对于技术,师哥师姐们都已经写了好多博客,这也是我在敲机房几乎没写这方面的博客的原因,不过别人的再好也是别人的,下面说说自己的. (一)数据库的设计 其实虽然说是数据库的 ...
随机推荐
- bootstrap 弹窗 数据清除
bootstrap modal操作简单易用, //清除弹窗原数据 $("#create_modal").on("hidden.bs.modal", functi ...
- js_页面关闭beforeunload事件
做圆桌爆文公众号的时候,需要对阅读的文章进行时间统计.是这个公众号的核心功能,客户把文章转发到朋友圈或者转给朋友,记录谁阅读此文章和阅读时长进行记录,从而展示给客户. 功能点是,关闭页面时触发事件,请 ...
- Android中的异常情况
1.setText()方法中,如果参数是int类型,Android会把它当做是一个id查找,报以下异常,因此解决办法就是将参数转化为String类型 如:setText(num) è setText( ...
- $(document).ready 和 window.onload 的区别
1.相同点 两者都用于在网页加载完后执行相应代码块. 2.不同点 window.onload 在创建完 DOM 树后,所有外部资源(图片.Flash 动画等)加载完成,且整个页面在浏览器窗口中显示完毕 ...
- (十九)git版本管理软件——搭建git服务器
创建管理员git 为管理员用户添加sudo权限 生成管理员秘钥 设置管理员git提交账号和邮箱 下载安装gitolite 启动gitolite 添加项目版本库 添加项目成员 项目成员下载项目 gito ...
- HDU 6183 Color it 线段树
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6183 题意: 有四种操作: 0:清除所有点 1 x y c : 给点(x, y)添加一种颜色c(颜色不 ...
- 访问WEB-INF目录中的文件
WEB-INF下面的文件具有安全性,直接在浏览器中输入地址是访问不到的,可以通过servlet来访问. 方法1: 利用<jsp-file>/WEB-INF/a.jsp</jsp-fi ...
- JS常用操作方法
1.splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目. 注释:该方法会改变原始数组. 1 <script type="text/javascript"& ...
- 流程控制--while
/* while 是在有条件控制的情况下 进行的循环 */ [root@localhost test1]# vim .py //ADD #!/usr/bin/python n = while True ...
- C++11——Use auto keyword in C++11
版权声明:本文系原创,转载请注明来源. Compile your program with: g++ -std=c++ -o target_name filen_ame.cpp or: g++ -st ...