机房收费系统——上机和下机

2024-05-25 15:58

本文主要是介绍机房收费系统——上机和下机,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

机房收费系统的难点之一就是上机和下机的部分,不仅要考虑基本的功能实现,还有下机的用户消费情况的分析,我仅提供我自己简单编写的代码和思路图,希望可以等到大家的指导。

上机:


附代码:'上机操作主要有显示上机信息(获取时间),更新数据库中的上机表中的信息


Private Sub CmdOk_Click()


    Dim StrSQL As String
    Dim strSQL2 As String
    Dim strSQL3 As String
    Dim strSQL4 As String
    Dim strSQL5 As String
    Dim StrSQL6 As String
    
    Dim strMsgText As String
    Dim strMsgText2 As String
    Dim strMsgText3 As String
    Dim strMsgText4 As String
    Dim strMsgText5 As String
    Dim strMsgText6 As String
    
    Dim objRst As ADODB.Recordset
    Dim objRst2 As ADODB.Recordset
    Dim objRst3 As ADODB.Recordset
    Dim objRst4 As ADODB.Recordset
    Dim objRst5 As ADODB.Recordset
    Dim objRst6 As ADODB.Recordset
    
 
  '判断卡号是否为空
 
    If Trim(txtCardNo.Text) = "" Then
        MsgBox "请输入卡号!", vbOKOnly + vbExclamation, "警告!"
        txtCardNo.SetFocus
        Exit Sub
    Else
        If IsNumeric(txtCardNo.Text) = False Then
            MsgBox "卡号输入必须为数字", vbOKOnly + vbExclamation, "警告!"
            txtCardNo.Text = ""
            txtCardNo.SetFocus
            Exit Sub
        End If
     '查询数据库里学生基本信息表
 
        StrSQL = "select * from student_Info where cardno='" & Trim(txtCardNo.Text) & "'"
        Set objRst = ExecuteSQL(StrSQL, strMsgText)
        
    '判读该卡号是否注册
             
        If objRst.BOF And objRst.EOF Then
            MsgBox "该卡号未注册,请先注册信息!", vbOKOnly + vbExclamation, "警告!"
            txtCardNo.Text = ""
            txtCardNo.SetFocus
            Exit Sub
        Else
        
    '判断卡号是否正在上机


            strSQL2 = "select * from online_Info where cardno='" & Trim(txtCardNo.Text) & "'and status= '上机'"
            Set objRst2 = ExecuteSQL(strSQL2, strMsgText2)
            
            If objRst2.EOF = False Then
                Label20.Caption = "该卡正在上机,不能重复上机!"
                txtCardNo.Text = ""
                txtCardNo.SetFocus
                Exit Sub
            End If
            
                strSQL3 = "select * from student_Info where cardno='" & Trim(txtCardNo.Text) & "'"
                Set objRst3 = ExecuteSQL(strSQL3, strMsgText3)
                           
                strSQL4 = "select * from basicdata_Info "
                Set objRst4 = ExecuteSQL(strSQL4, strMsgText4)
                
                If objRst3.Fields(14) < objRst4.Fields(5) Then
                    MsgBox "金额不足,请充值!", vbOKOnly + vbExclamation, "提示"
                    txtCardNo.Text = ""
                    txtCardNo.SetFocus
                    
                    Exit Sub


                Else
    '显示该卡号的一些基本信息
 
                  txtSID.Text = objRst3.Fields(1)
                  txtdepartment.Text = objRst3.Fields(4)
                  txtType.Text = objRst3.Fields(8)
                  txtname.Text = objRst3.Fields(3)
                  txtsex.Text = objRst3.Fields(2)
                  txtloginondate.Text = Date
                  txtloginontime.Text = Time
                  
    '将上机前的余额提出来,用于下机时计算余额
 
                  txtbalance.Text = objRst3.Fields(14)
            
                  ontime = Time
                  
                  Label20.Caption = "欢迎光临!"
            
    '将该卡上机的信息填入到online_Info表里


                strSQL5 = "select * from online_Info "
                Set objRst5 = ExecuteSQL(strSQL5, strMsgText5)


                objRst5.AddNew
                
                objRst5.Fields(0) = txtCardNo.Text
                objRst5.Fields(1) = txtSID.Text
                objRst5.Fields(2) = txtname.Text
                objRst5.Fields(3) = Trim(txtType.Text)
                objRst5.Fields(4) = txtdepartment.Text
                objRst5.Fields(5) = txtsex.Text
                objRst5.Fields(6) = Date
                objRst5.Fields(7) = Time
                objRst5.Fields(8) = UserName
                objRst5.Fields(9) = txtbalance.Text
                objRst5.Fields(10) = "上机"
                
                objRst5.Update
                
    '查询此时正在上机的人数
               
                StrSQL6 = "select * from online_Info where status='上机'"
                Set objRst6 = ExecuteSQL(StrSQL6, strMsgText6)
                
                If objRst6.EOF = True Then
                    Label18.Caption = 0
                Else
                    Label18.Caption = objRst6.RecordCount
                End If
            End If
           
        End If

End If

End Sub


下机:


附代码:

'下机的操作主要有,获取下机信息,更新注册表、上机表中的相关字段
'添加下机表中信息,计算上机时间和上机费用、余额等并添加到相应的数据表中


Private Sub cmdOff_Click()
    Dim StrSQL As String
    Dim StrSQL1 As String
    Dim strSQL2 As String
    Dim strSQL3 As String
    Dim strSQL4 As String
    Dim strSQL5 As String
    Dim StrSQL6 As String
    
    Dim strMsgText As String
    Dim strMsgText1 As String
    Dim strMsgText2 As String
    Dim strMsgText3 As String
    Dim strMsgText4 As String
    Dim strMsgText5 As String
    Dim strMsgText6 As String
    
    Dim objRst As ADODB.Recordset
    Dim objRst1 As ADODB.Recordset
    Dim objRst2 As ADODB.Recordset
    Dim objRst3 As ADODB.Recordset
    Dim objRst4 As ADODB.Recordset
    Dim objRst5 As ADODB.Recordset
    Dim objRst6 As ADODB.Recordset
    
    Dim intTime As Single
    Dim intTime1 As Single
    Dim fixedRate As Single
    Dim pay As Currency
    Dim returncash As Currency
    Dim temporary As Single
    
    '判断卡号的输入情况
    
    If Trim(txtCardNo.Text) = "" Then
        MsgBox "请输入卡号!", vbOKOnly, "警告!"
        txtCardNo.SetFocus
        Exit Sub
    Else
        If IsNumeric(txtCardNo.Text) = False Then
            MsgBox "卡号输入必须为数字", vbOKOnly + vbExclamation, "警告!"
            txtCardNo.Text = ""
            txtCardNo.SetFocus
            Exit Sub
        End If
    End If
    
    '判读该卡号是否注册
    
    StrSQL = "select * from student_Info where cardno='" & Trim(txtCardNo.Text) & "'"
    Set objRst = ExecuteSQL(StrSQL, strMsgText)
    
    If objRst.BOF And objRst.EOF Then
        MsgBox "该卡号未注册,请先注册信息!", vbOKOnly, "警告!"
        txtCardNo.Text = ""
        txtCardNo.SetFocus
        Exit Sub
          
    End If


    '判断该卡是否正在上机
    
    StrSQL1 = "select * from online_Info where status='上机'"
    Set objRst1 = ExecuteSQL(StrSQL1, strMsgText1)


    If objRst1.EOF And objRst1.BOF = True Then
        Label20.Caption = "该卡没有上机,不能进行下机处理!"
        txtCardNo.Text = ""
        txtCardNo.SetFocus
        Exit Sub
    Else
 '显示下机的一些信息
'        strSQL2 = "select * from online_Info where cardno='" & txtCardNo.Text & "'"
'        Set objRst2 = ExecuteSQL(strSQL2, strMsgText2)
        
        txtloginoffdate.Text = Date
        outtime = Time
        outdate = Date
        txtloginofftime.Text = Time
        
        Dim loginontime As String
        Dim loginondate As String
        loginondate = objRst1.Fields("loginondate")
        loginontime = objRst1.Fields("loginontime")
        ontime = CDate(objRst1.Fields("loginontime"))
        ondate = CDate(objRst1.Fields("loginondate"))
'
        txtname.Text = objRst1.Fields(2)
        txtloginondate.Text = objRst1.Fields(6)
        txtloginontime.Text = objRst1.Fields(7)
        objRst1.Fields(10) = "下机"
        
        strSQL2 = "select * from student_Info where cardno='" & Trim(txtCardNo.Text) & "'"
        Set objRst2 = ExecuteSQL(strSQL2, strMsgText2)
        
        txtSID.Text = objRst2.Fields(1)
        txtdepartment.Text = objRst2.Fields(4)
        txtsex.Text = objRst2.Fields(2)
        txtType.Text = objRst2.Fields(8)
        
        strSQL4 = "select * from online_Info where cardno='" & Trim(txtCardNo.Text) & "' "
        Set objRst4 = ExecuteSQL(strSQL4, strMsgText4)
              
        objRst4.Fields(10) = "正常下机"


        strSQL3 = "select * from line_Info "
        Set objRst3 = ExecuteSQL(strSQL3, strMsgText3)


        
        objRst3.AddNew
        
        objRst3.Fields(0) = txtCardNo.Text
        objRst3.Fields(1) = txtSID.Text
        objRst3.Fields(2) = txtname.Text
        objRst3.Fields(3) = Trim(txtType.Text)
        objRst3.Fields(4) = Trim(txtdepartment.Text)
        objRst3.Fields(5) = txtsex.Text
        objRst3.Fields(6) = objRst1.Fields(6)
        objRst3.Fields(7) = objRst1.Fields(7)
        objRst3.Fields(8) = Date
        objRst3.Fields(9) = Time
        objRst3.Fields(13) = objRst4.Fields(10)
        objRst3.Fields(14) = UserName
  
     
 '计算上机的时间
        
        txtloginoffdate.Text = Date
        txtloginofftime.Text = Time
        
        txtdate = DateDiff("n", ondate, outdate)
        txttime = DateDiff("n", ontime, outtime)
        txttime.Text = Int(txttime) + Int(txtdate)
        intTime = txttime.Text
        
         objRst3.Fields(10) = Trim(txttime.Text)
         
         
 '计算上机的费用
  
         strSQL5 = "select * from basicdata_Info "
         Set objRst5 = ExecuteSQL(strSQL5, strMsgText5)
         
     '查询固定用户30分钟的费用
     
         fixedRate = Val(objRst5.Fields(0))
         
    '判断上机时间是否超过了准备时间,没超过则花费为0
    
        If intTime < (objRst5.Fields(4)) Then
            
            txtmoney.Text = 0
            
            objRst3.Fields(11) = txtmoney.Text
            returncash = Trim(txtbalance.Text) - Trim(txtmoney.Text)
            objRst3.Fields(12) = returncash
            objRst3.Update
            objRst4.Fields(9) = objRst3.Fields(12)
            objRst4.Update
            objRst2.Fields(14) = objRst3.Fields(12)
            objRst2.Update
            
            Exit Sub
            
        Else


    '判断上机时间是否超过至少上机时间,没有则当成已经上了30分钟
    
            If intTime <= objRst5.Fields(3) Then
            
                txtmoney.Text = fixedRate
                objRst3.Fields(11) = txtmoney.Text
                returncash = Trim(txtbalance.Text) - Trim(txtmoney.Text)
                objRst3.Fields(12) = returncash
                objRst3.Update
                objRst4.Fields(9) = objRst3.Fields(12)
                objRst4.Update
                objRst2.Fields(14) = objRst3.Fields(12)
                objRst2.Update
                Exit Sub
                
            Else
    '判断消耗的时间能否正好是30的倍数,判断是不是有超出不满足30分钟的部分,这部分仍然按照30分钟收费
                
                If Val(intTime) Mod 30 = 0 Then
                    txtmoney.Text = Val(Val(intTime) \ 30) * fixedRate
                    objRst3.Fields(11) = txtmoney.Text
                    returncash = Trim(txtbalance.Text) - Trim(txtmoney.Text)
                    objRst3.Fields(12) = returncash
                    objRst3.Update
                    objRst4.Fields(9) = objRst3.Fields(12)
                    objRst4.Update
                    objRst2.Fields(14) = objRst3.Fields(12)
                    objRst2.Update
                Else
                    txtmoney.Text = Val(Val(intTime) \ 30 + 1) * fixedRate
                    objRst3.Fields(11) = txtmoney.Text
                    returncash = Trim(txtbalance.Text) - Trim(txtmoney.Text)
                    objRst3.Fields(12) = returncash
                    objRst3.Update
                    objRst4.Fields(9) = objRst3.Fields(12)
                    objRst4.Update
                    objRst2.Fields(14) = objRst3.Fields(12)
                    objRst2.Update
                End If
                
            End If
           
        End If
  
          
          StrSQL6 = "select * from online_Info where status='上机'"
          Set objRst6 = ExecuteSQL(StrSQL6, strMsgText6)
          
          If objRst6.EOF = True Then
            
                Label18.Caption = objRst6.RecordCount
          End If
          
          Label20.Caption = "欢迎下次再来!"
End If
          
End Sub

因为当时创建的数据库中有上机表和上机记录表,所以每次在更新数据的时候都需要分别对两个表进行修改,我们可以用一张表同时存储两部分信息,减少数据的冗余,并且可以节省程序运行的时间,加快查询速度。代码仍然在优化,继续、、、

这篇关于机房收费系统——上机和下机的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1001956

相关文章

通信系统网络架构_2.广域网网络架构

1.概述          通俗来讲,广域网是将分布于相比局域网络更广区域的计算机设备联接起来的网络。广域网由通信子网于资源子网组成。通信子网可以利用公用分组交换网、卫星通信网和无线分组交换网构建,将分布在不同地区的局域网或计算机系统互连起来,实现资源子网的共享。 2.网络组成          广域网属于多级网络,通常由骨干网、分布网、接入网组成。在网络规模较小时,可仅由骨干网和接入网组成

Linux系统稳定性的奥秘:探究其背后的机制与哲学

在计算机操作系统的世界里,Linux以其卓越的稳定性和可靠性著称,成为服务器、嵌入式系统乃至个人电脑用户的首选。那么,是什么造就了Linux如此之高的稳定性呢?本文将深入解析Linux系统稳定性的几个关键因素,揭示其背后的技术哲学与实践。 1. 开源协作的力量Linux是一个开源项目,意味着任何人都可以查看、修改和贡献其源代码。这种开放性吸引了全球成千上万的开发者参与到内核的维护与优化中,形成了

PS系统教程25

介绍软件 BR(bridge) PS 配套软件,方便素材整理、管理素材 作用:起到桥梁作用 注意:PS和BR尽量保持版本一致 下载和安装可通过CSDN社区搜索,有免费安装指导。 安装之后,我们打开照片只需双击照片,就自动在Ps软件中打开。 前提:电脑上有PS软件 三种预览格式 全屏预览 评星级 直接按数字键就可以 方向键可以更换图片 esc退出 幻灯片放

风水研究会官网源码系统-可展示自己的领域内容-商品售卖等

一款用于展示风水行业,周易测算行业,玄学行业的系统,并支持售卖自己的商品。 整洁大气,非常漂亮,前端内容均可通过后台修改。 大致功能: 支持前端内容通过后端自定义支持开启关闭会员功能,会员等级设置支持对接官方支付支持添加商品类支持添加虚拟下载类支持自定义其他类型字段支持生成虚拟激活卡支持采集其他站点文章支持对接收益广告支持文章评论支持积分功能支持推广功能更多功能,搭建完成自行体验吧! 原文

Django 路由系统详解

Django 路由系统详解 引言 Django 是一个高级 Python Web 框架,它鼓励快速开发和干净、实用的设计。在 Django 中,路由系统是其核心组件之一,负责将用户的请求映射到相应的视图函数或类。本文将深入探讨 Django 的路由系统,包括其工作原理、配置方式以及高级功能。 目录 路由基础URL 映射路由参数命名空间URL 反向解析路由分发include 路由路由修饰符自

【图像识别系统】昆虫识别Python+卷积神经网络算法+人工智能+深度学习+机器学习+TensorFlow+ResNet50

一、介绍 昆虫识别系统,使用Python作为主要开发语言。通过TensorFlow搭建ResNet50卷积神经网络算法(CNN)模型。通过对10种常见的昆虫图片数据集(‘蜜蜂’, ‘甲虫’, ‘蝴蝶’, ‘蝉’, ‘蜻蜓’, ‘蚱蜢’, ‘蛾’, ‘蝎子’, ‘蜗牛’, ‘蜘蛛’)进行训练,得到一个识别精度较高的H5格式模型文件,然后使用Django搭建Web网页端可视化操作界面,实现用户上传一

OSG数学基础:坐标系统

坐标系是一个精确定位对象位置的框架,所有的图形变换都是基于一定的坐标系进行的。三维坐标系总体上可以分为两大类:左手坐标系和右手坐标系。常用的坐标系:世界坐标系、物体坐标系和摄像机坐标系。 世界坐标系 世界坐标系是一个特殊的坐标系,它建立了描述其他坐标系所需要的参考框架。从另一方面说,能够用世界坐标系来描述其他坐标系的位置,而不能用更大的、外部的坐标系来描述世界坐标系。世界坐标系也被广泛地

LoRaWAN在嵌入式网络通信中的应用:打造高效远程监控系统(附代码示例)

引言 随着物联网(IoT)技术的发展,远程监控系统在各个领域的应用越来越广泛。LoRaWAN(Long Range Wide Area Network)作为一种低功耗广域网通信协议,因其长距离传输、低功耗和高可靠性等特点,成为实现远程监控的理想选择。本文将详细介绍LoRaWAN的基本原理、应用场景,并通过一个具体的项目展示如何使用LoRaWAN实现远程监控系统。希望通过图文并茂的讲解,帮助读

获取Windows系统版本号(转)

https://blog.csdn.net/sunflover454/article/details/51525179

混合密码系统解析

1. 概述         混合密码系统(hybrid cryptosystem)是将对称密码和非对称密码的优势相结合的方法。一般情况下,将两种不同的方式相结合的做法就称为混合(hybrid)。用混合动力汽车来类比的话,就相当于是一种将发动机(对称密码)和电动机(非对称密码)相结合的系统。         混合密码系统中会先用快速的对称密码来对消息进行加密,这样消息就被转换为了密文从而也就保证