存储过程,解决机房收费系统多表操作问题

2024-08-26 13:48

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

一、背景

     机房收费系统也敲了一段时间了,其中也遇到了很多问题,开始师父叫我先敲三层,后面再逐步添加存储过程、泛型、七层和设计模式等内容。开始觉得能敲三层就很不错了,但是敲了将近10个窗体的时候,觉得只敲三层太没意思了,而且每涉及到多表操作的时候,我都要敲一个过程,每一层里我都要写多一个过程,于是就想到了存储过层,觉得不能就这么简单没意思的罗列代码。

    下面以注册为例,先看看我没有加存储过程的D层代码

<span style="font-family:KaiTi_GB2312;font-size:24px;"> Public Function FillStudent(ByVal student As Model.studentEntity) As Model.studentEntityDim conn As New SqlConnection   '创建连接对象  Dim cmd As New SqlCommand       '创建命令对象  conn = New SqlConnection(Dtutil.connstring())  '连接数据库  cmd.Connection = conn '初始化cmd.CommandText = "Insert INTO Students(studentNO,studentName,sex,class,grade,cardNo ,department,static ,money,type,userID,checks,RegisterDate,RegisterTime)values(@studentNO,@studentName,@sex,@class,@grade,@cardNo,@checks,@Department,@static,@money,@type,@userNo,@RegisterDate,@RegisterTime)"cmd.Parameters.Add(New SqlParameter("@studentNO", student.studentNo))cmd.Parameters.Add(New SqlParameter("@studentName", student.studentName))cmd.Parameters.Add(New SqlParameter("@sex", student.Sex))cmd.Parameters.Add(New SqlParameter("@class", student.ClassNo))cmd.Parameters.Add(New SqlParameter("@grade", student.Grade))cmd.Parameters.Add(New SqlParameter("@CardNO", student.CardNo))cmd.Parameters.Add(New SqlParameter("@Department", student.Department))cmd.Parameters.Add(New SqlParameter("@static", student.StaticCard))cmd.Parameters.Add(New SqlParameter("@money", student.Money))cmd.Parameters.Add(New SqlParameter("@type", student.Type))cmd.Parameters.Add(New SqlParameter("@userNO", student.UserNo))cmd.Parameters.Add(New SqlParameter("@checks", "未结账"))student.RegisterDate = Format(Now, "yyyy/MM/dd")student.RegisterTime = Format(Now, "HH:mm:ss")cmd.Parameters.Add(New SqlParameter("@RegisterDate", student.RegisterDate))cmd.Parameters.Add(New SqlParameter("@RegisterTime", student.RegisterTime))conn.Open()num = cmd.ExecuteNonQuery() '执行插入命令conn.Close()Return studentsEnd Function</span>

    这也只是一部分代码,因为注册还涉及到充值表,于是,我还有一段基本上一样的代码。所以总觉得自己真的像个码农,不懂得思考,机械式的敲着重复的代码。但是我又不了解存储过程,我也不知道怎么用。于是翻了一下《数据库系统原理》。

二、存储过程

1、了解

 存储过程是存放咱服务器上的预先的编译好的SQL语句。存储过程的优点主要有提供了安全机制、改进执行性能、减少了网络流量和增强了代码的重用性。了解到存储过程有这么多优点,看来我是必须要学会用它了。

它的基本语法规则是:

<span style="font-family:KaiTi_GB2312;font-size:24px;">CREATE  PROCEDURE  PROC_NAME@[参数名] [类型],@[参数名] [类型]……ASBEGIN[过程体].........END</span>

2、使用

   接下来依旧是以注册为例,看看在机房收费系统同中如何使用存储过程。

1)新建存储过程

                                                    

   2)在SQL server中编译代码

    

<span style="font-family:KaiTi_GB2312;font-size:24px;">CREATE PROCEDURE PROC_Register  --定义参数@Cardno varchar(6),@money decimal(5,1),@userID varchar(60) ,@dates date ,@times time ,@checks nvarchar(20) ,@comment nvarchar(20),
@studentName nvarchar(10) ,@studentNO varchar(18),@type nvarchar(10),@static nvarchar(50),@RegisterDate date,@RegisterTime time,
@sex varchar(6) ,@class nvarchar(20),@grade nvarchar(20),@department nvarchar(30),@addmoney decimal(5,1)
as
--
begin
--对表进行操作
insert into Students (studentNO ,studentName ,sex,class, grade, cardNo ,department,static ,money,type,userID,checks,RegisterDate,RegisterTime)values(@studentNo,@studentName ,@sex ,@class ,@grade ,@Cardno  ,@department ,@static   ,@money  ,@type ,@userID ,@checks ,@RegisterDate ,@RegisterTime )
insert into Recharge (cardNo ,addmoney ,money ,dates ,times ,userID ,comment ,checks )values(@Cardno ,@addmoney ,@money ,@dates ,@times,@userID ,@comment ,@checks )
end
</span>
   代码编译完成后对其进行执行,执行成功后数据库中遍生成了存储过程。

   3)vb.net中机房收费系统中D层代码的编写

<span style="font-family:KaiTi_GB2312;font-size:24px;">Imports System.Data
Imports System.Data.SqlClient
Imports System.Configuration
Public Class RegisterDAL : Implements IDAL.IRegisterPublic Function Insert(ByVal student As Model.studentEntity, ByVal card As Model.RechargeEntity) As Boolean Implements IDAL.IRegister.Insert'定义SqlHelper实例  Dim cmdType As CommandType = CommandType.StoredProcedure       '定义数据库命令类型  Dim cmdText As String = "Proc_Register"                        '数据库执行字符串  Dim parameters As SqlParameter()                               '定义参数数组,负责向存储过程中的变量传值  '为参数数组中的参数一一赋值  parameters = {New SqlParameter("@studentNO", student.studentNo),New SqlParameter("@studentName", student.studentName),New SqlParameter("@sex", student.Sex),New SqlParameter("@class", student.ClassNo),New SqlParameter("@grade", student.Grade),New SqlParameter("@Cardno", student.CardNo),New SqlParameter("@money", student.Money),New SqlParameter("@type", student.Type),New SqlParameter("@RegisterDate", student.RegisterDate),New SqlParameter("@RegisterTime", student.RegisterTime),New SqlParameter("@addmoney", student.Money),New SqlParameter("@dates", student.RegisterDate),New SqlParameter("@times", student.RegisterTime),New SqlParameter("@department", student.Department),New SqlParameter("@static", "使用"),New SqlParameter("@checks", "未结账"),New SqlParameter("@comment", "注册"),New SqlParameter("@userID", student.UserNo)}Return SqlHelper.ExecuteNoQuery(cmdText, CommandType.StoredProcedure, parameters)End FunctionEnd Class
</span>

    这样看上去D层代码就比之前的少了很多。

三、小结

存储过程的使用,也让接触了很多新的我不懂或不太了解的内容,所以在学着使用存储过程的过程中我也学会了接口的使用,进一步了解了sqlhelper这部分内容,也学会了配置文件的使用,而且到现在我也遇到了其他问题,如外观模式和泛型等。

路漫漫其修远兮,吾将上下而求索!

这篇关于存储过程,解决机房收费系统多表操作问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

HDFS—存储优化(纠删码)

纠删码原理 HDFS 默认情况下,一个文件有3个副本,这样提高了数据的可靠性,但也带来了2倍的冗余开销。 Hadoop3.x 引入了纠删码,采用计算的方式,可以节省约50%左右的存储空间。 此种方式节约了空间,但是会增加 cpu 的计算。 纠删码策略是给具体一个路径设置。所有往此路径下存储的文件,都会执行此策略。 默认只开启对 RS-6-3-1024k

作业提交过程之HDFSMapReduce

作业提交全过程详解 (1)作业提交 第1步:Client调用job.waitForCompletion方法,向整个集群提交MapReduce作业。 第2步:Client向RM申请一个作业id。 第3步:RM给Client返回该job资源的提交路径和作业id。 第4步:Client提交jar包、切片信息和配置文件到指定的资源提交路径。 第5步:Client提交完资源后,向RM申请运行MrAp

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设