机房收费系统之上下机

机房收费系统比较难的地方有三个,上下机,组合查询,报表结账。

这次和大家探讨一下上下机问题。上下机首先是算时间。

首先是时间差:

        diffmtime = Val(DateDiff("n", strSjtime, strXjtime)) ’时间差以分表示
        diffhtime = Val(DateDiff("h", strSjtime, strXjtime)) ‘时间差以小时表示
        diffdtime = Val(DateDiff("d", strSjtime, strXjtime)) ’时间差以天表示

时间分三种情况:

一、当天结账

当天结账时间是正数,可以直接用diffhtime进行计算,下面是判断条件


If diffhtime >= 0 And diffdtime = 0 Then

二、隔天结账,但不到一天24小时

在这种情况下计算的差(以分钟表示的)是负的,所以要把他们变成正的再进行计算。


elseif diffhtime < 0 And diffdtime > 0then  

diffmtime = 24 *60 + diffmtime      ‘将时间变成正的

三、一天以上结账

除了上面的两种情况就是一天以上的了,时间差需要用(以天表示的和以小时表示的)时间差进行计算。


else                                    

   diffmtime=(diffdtime*24+diffhtime)*60

好了以上就是时间的判断与计算,下面让我们看看消费金额是如何利用基本数据表里的数据进行计算的。

  一、准备时间内不计费

二、消费时间对递增时间求余若大于最小上机时间则多算几个递增时间的消费

三、消费时间对递增时间求余若小于最小上机时间则就算当前的有几个递增时间进行计费

        下面是固定用户的消费时间的计算

注:我理解的最小上机时间是过了这个时间就多收一个时间单位的钱,而不是在这个时间内不能下机。

最后再把数据更新到数据库里就可以了。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 29
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 29
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值