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

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

相关文章

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

2.1/5.1和7.1声道系统有什么区别? 音频声道的专业知识科普

《2.1/5.1和7.1声道系统有什么区别?音频声道的专业知识科普》当设置环绕声系统时,会遇到2.1、5.1、7.1、7.1.2、9.1等数字,当一遍又一遍地看到它们时,可能想知道它们是什... 想要把智能电视自带的音响升级成专业级的家庭影院系统吗?那么你将面临一个重要的选择——使用 2.1、5.1 还是

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

Ubuntu系统怎么安装Warp? 新一代AI 终端神器安装使用方法

《Ubuntu系统怎么安装Warp?新一代AI终端神器安装使用方法》Warp是一款使用Rust开发的现代化AI终端工具,该怎么再Ubuntu系统中安装使用呢?下面我们就来看看详细教程... Warp Terminal 是一款使用 Rust 开发的现代化「AI 终端」工具。最初它只支持 MACOS,但在 20

windows系统下shutdown重启关机命令超详细教程

《windows系统下shutdown重启关机命令超详细教程》shutdown命令是一个强大的工具,允许你通过命令行快速完成关机、重启或注销操作,本文将为你详细解析shutdown命令的使用方法,并提... 目录一、shutdown 命令简介二、shutdown 命令的基本用法三、远程关机与重启四、实际应用

Debian如何查看系统版本? 7种轻松查看Debian版本信息的实用方法

《Debian如何查看系统版本?7种轻松查看Debian版本信息的实用方法》Debian是一个广泛使用的Linux发行版,用户有时需要查看其版本信息以进行系统管理、故障排除或兼容性检查,在Debia... 作为最受欢迎的 linux 发行版之一,Debian 的版本信息在日常使用和系统维护中起着至关重要的作

什么是cron? Linux系统下Cron定时任务使用指南

《什么是cron?Linux系统下Cron定时任务使用指南》在日常的Linux系统管理和维护中,定时执行任务是非常常见的需求,你可能需要每天执行备份任务、清理系统日志或运行特定的脚本,而不想每天... 在管理 linux 服务器的过程中,总有一些任务需要我们定期或重复执行。就比如备份任务,通常会选在服务器资

TP-LINK/水星和hasivo交换机怎么选? 三款网管交换机系统功能对比

《TP-LINK/水星和hasivo交换机怎么选?三款网管交换机系统功能对比》今天选了三款都是”8+1″的2.5G网管交换机,分别是TP-LINK水星和hasivo交换机,该怎么选呢?这些交换机功... TP-LINK、水星和hasivo这三台交换机都是”8+1″的2.5G网管交换机,我手里的China编程has

基于Qt实现系统主题感知功能

《基于Qt实现系统主题感知功能》在现代桌面应用程序开发中,系统主题感知是一项重要的功能,它使得应用程序能够根据用户的系统主题设置(如深色模式或浅色模式)自动调整其外观,Qt作为一个跨平台的C++图形用... 目录【正文开始】一、使用效果二、系统主题感知助手类(SystemThemeHelper)三、实现细节

CentOS系统使用yum命令报错问题及解决

《CentOS系统使用yum命令报错问题及解决》文章主要讲述了在CentOS系统中使用yum命令时遇到的错误,并提供了个人解决方法,希望对大家有所帮助,并鼓励大家支持脚本之家... 目录Centos系统使用yum命令报错找到文件替换源文件为总结CentOS系统使用yum命令报错http://www.cppc