机房收费系统之上机、下机

简介:

还记得,从八月一日开始做机房收费系统,到今天已经是八月十二号了。期间,碰到了很多困难,有时候,就想这个机房收费系统能成功吗?解决了一个问题,另一个问题又接踵而至了,心里同样很清楚,下面还有好多好多问题。于是乎,根本不敢想后面的路。

前三天吧,开始了主界面上下机代码的编写。一个主界面,包含了15个文本框要填,可想而知,这真的是一个庞大的工程。

在开始动工之前,自己还是分析了整个流程,不然混乱的自己,早晚会被带沟里去的。

首先是上机:


在这一流程中,要注意的是,在LineRecord表中不可出现相同的卡号的记录,否则无法进行准确判断是否正在上机。

下面是下机:


两者加之一起,就把卡号上下机操作搞定了。在此界面上,还有三个需要通过计算才可以得到的:上机人数、消费时间和消费金额。

这个过程真的花费了我好长的时间,一遍遍理思路,掉沟里好几次,最后终于上岸了。

(1)消费人数的计算,两种方法。通过查找“正在上机”的字段的个数。

一是可以利用循环查找。把此记录集中所有记录都遍历一遍,最后得出个数。

<span style="font-family:KaiTi_GB2312;font-size:24px;"><strong>'利用循环计算人数
            strTxtSQL = "select * from tb_linerecord where status = '正在上机' "
            Set mrc = ExecuteSQL(strTxtSQL, strMsgText)
            Sum = 0
            Do While Not mrc.EOF
                Sum = Sum + 1
                mrc.MoveNext
            Loop
            txtNowCount.Text = Sum</strong></span>

二是利用SQL语句,直接在数据库中计算,再将其值返回到VB中。

<span style="font-family:KaiTi_GB2312;font-size:24px;"><strong> '计算上机人数,利用SQL语句
            strTxtSQL = "select count(status) as count from tb_lineRecord where status = '正在上机'  "
            Set mrc = ExecuteSQL(strTxtSQL, strMsgText)
            Sum = mrc("count").Value
            txtNowCount.Text = Sum</strong></span>
这里用到的是select Count语句,既然碰到了,不妨多了解了解吧。

(2)消费时间的计算

首先列出三个时间:

T1=准备时间(Basic Data表)中

T2=总消费时间(从上机命令生效开始计时)

T3=实际消费时间(T2-T1)

这里用到了DateDiff(时间间隔函数),特别方便。

<span style="font-family:KaiTi_GB2312;font-size:24px;"><strong>            'CDate()转换为日期函数
            '实际消费时间=总消费时间-准备时间
            txtConsumeTime.Text = DateDiff("n", CDate(txtOnLineDate.Text), CDate(txtLineDate.Text))
            txtConsumeTime.Text = txtConsumeTime.Text + DateDiff("n", CDate(txtOnLineTime.Text), CDate(txtLineTime.Text))
            txtConsumeTime.Text = txtConsumeTime.Text - vntpreparedtime</strong></span>

(3)计算消费金额

<span style="font-family:KaiTi_GB2312;font-size:24px;"><strong>            '在准备时间段内,可自由下机
            '判断消费时间是否大于准备时间
            If Trim(txtConsumeTime.Text) < 0 Then    '消费时间少于准备时间,消费时间为0
               txtConsumeTime.Text = 0
               txtConsumeMoney.Text = 0
               MsgBox "已成功下机,消费时间为0!", vbOKOnly + vbExclamation, "下机提示"
            Else
            '判断消费时间是否大于最低消费时间
                 If Trim(txtConsumeTime.Text) < vntlimitedtime Then
                    txtConsumeTime.Text = txtConsumeTime.Text      '消费时间小于最低消费时间,消费金额为最低消费金额
                    txtConsumeMoney.Text = vntlimitedmoney
                 Else
            '消费时间大于最低消费时间,则根据用户类型,计算消费金额</strong></span>
<span style="font-family:KaiTi_GB2312;font-size:24px;"><strong><span style="white-space:pre">	</span>    'Round()为四舍五入函数
                    If Trim(txtUserType.Text) = "固定用户" Then
                       txtConsumeMoney.Text = Round(txtConsumeTime.Text / Addtime * fixedusercost) + fixedusercost
                    Else
                       txtConsumeMoney.Text = Round(txtConsumeTime.Text / Addtime * casualusercost) + casualusercost
                    End If
                 End If
             End If</strong></span>
后两者的计算是分不开的,所以必须很清楚的知道它们间的关系。有个流程图,自己才没有被弄得那么混。


最后的最后,我终于把主界面的所有文本框都搞定了。


这个过程中,一次次跌倒,一次次头晕,可是,自己强大的内心还是战胜了所有的敌人,没有什么不可以。其实正确地应该是不需要去想后面的路,只要走好脚下的路,一步一步,就一定可以。路,还在自己脚下。




目录
相关文章
|
编解码 网络协议
如何轻松地 rip 3D Blu-ray:详细步骤指南
随着3D电影和家庭影院的普及,越来越多的人希望将3D Blu-ray电影转换为数字文件,以便在多种设备上播放。本文介绍了使用DVDFab、MakeMKV+HandBrake和Leawo Blu-ray Ripper等软件轻松rip 3D Blu-ray的方法,帮助用户享受高质量的3D观影体验。这些工具不仅提供了便捷性和高质量的输出,还能节省存储空间。
934 9
|
监控 安全 Linux
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景,包括 ping(测试连通性)、traceroute(跟踪路由路径)、netstat(显示网络连接信息)、nmap(网络扫描)、ifconfig 和 ip(网络接口配置)。掌握这些命令有助于高效诊断和解决网络问题,保障网络稳定运行。
515 2
|
10月前
断路器/熔断器? 断路器的状态有哪些
● closed:关闭状态,断路器放行所有请求,并开始统计异常比例、慢请求比例。超过阈值则切换到open状态 ● open:打开状态,服务调用被熔断,访问被熔断服务的请求会被拒绝,快速失败,直接走降级逻辑。Open状态5秒后会进入half-open状态 ● half-open:半开状态,放行一次请求,根据执行结果来判断接下来的操作。 ○ 请求成功:则切换到closed状态 ○ 请求失败:则切换到open状态
|
域名解析 缓存 网络协议
DNS解析过程详解
【10月更文挑战第11天】 DNS(域名系统)解析过程是将域名转换为IP地址的关键步骤。客户端输入域名后,本地DNS服务器先检查缓存,如有记录则直接返回IP地址;否则依次向根DNS服务器、顶级域名服务器和权威DNS服务器查询,最终获取并缓存IP地址,返回给客户端,实现域名解析。这一过程确保了用户通过域名方便访问互联网资源。
1062 59
|
存储 前端开发 Java
Java后端如何进行文件上传和下载 —— 本地版(文末配绝对能用的源码,超详细,超好用,一看就懂,博主在线解答) 文件如何预览和下载?(超简单教程)
本文详细介绍了在Java后端进行文件上传和下载的实现方法,包括文件上传保存到本地的完整流程、文件下载的代码实现,以及如何处理文件预览、下载大小限制和运行失败的问题,并提供了完整的代码示例。
5619 2
|
C++ iOS开发 MacOS
常用的 VSCode 快捷键【大全】,提升你的编码速度
常用的 VSCode 快捷键【大全】,提升你的编码速度
常用的 VSCode 快捷键【大全】,提升你的编码速度
|
小程序
微信小程序5种路由跳转的区别
微信小程序5种路由跳转的区别
262 0
|
前端开发 JavaScript 定位技术
JavaScript 等待异步请求数据返回值后,继续执行代码 —— async await Promise的使用方法
JavaScript 等待异步请求数据返回值后,继续执行代码 —— async await Promise的使用方法
417 1
|
存储 达摩院 供应链
排产排程问题【数学规划的应用(含代码)】阿里达摩院MindOpt
**文章摘要:** 本文探讨了使用阿里巴巴达摩院的MindOpt优化求解器解决制造业中的排产排程问题。排产排程涉及物料流动、工序安排、设备调度等多个方面,通常通过数学规划方法建模。MindOpt支持线性规划、整数规划等,能有效处理大规模数据。案例以香皂制造工厂为例,考虑了多种油脂的购买、存储和生产计划,以及价格变化和存储成本。问题通过数学建模转化为MindOpt APL代码,求解器自动寻找最优解,以最大化利润。文章还提供了代码解析,展示了解决方案的细节,包括目标函数(利润最大化)、约束条件(如生产效率、库存管理)以及结果分析。
|
JavaScript 前端开发 Java
Node【工具 01】Node Version Manager nvm安装使用(Node.js版本管理工具)
Node【工具 01】Node Version Manager nvm安装使用(Node.js版本管理工具)
653 0

热门文章

最新文章