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

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

相关文章

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Linux查询服务器系统版本号的多种方法

《Linux查询服务器系统版本号的多种方法》在Linux系统管理和维护工作中,了解当前操作系统的版本信息是最基础也是最重要的操作之一,系统版本不仅关系到软件兼容性、安全更新策略,还直接影响到故障排查和... 目录一、引言:系统版本查询的重要性二、基础命令解析:cat /etc/Centos-release详

更改linux系统的默认Python版本方式

《更改linux系统的默认Python版本方式》通过删除原Python软链接并创建指向python3.6的新链接,可切换系统默认Python版本,需注意版本冲突、环境混乱及维护问题,建议使用pyenv... 目录更改系统的默认python版本软链接软链接的特点创建软链接的命令使用场景注意事项总结更改系统的默

在Linux系统上连接GitHub的方法步骤(适用2025年)

《在Linux系统上连接GitHub的方法步骤(适用2025年)》在2025年,使用Linux系统连接GitHub的推荐方式是通过SSH(SecureShell)协议进行身份验证,这种方式不仅安全,还... 目录步骤一:检查并安装 Git步骤二:生成 SSH 密钥步骤三:将 SSH 公钥添加到 github

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序