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

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

相关文章

IDEA和GIT关于文件中LF和CRLF问题及解决

《IDEA和GIT关于文件中LF和CRLF问题及解决》文章总结:因IDEA默认使用CRLF换行符导致Shell脚本在Linux运行报错,需在编辑器和Git中统一为LF,通过调整Git的core.aut... 目录问题描述问题思考解决过程总结问题描述项目软件安装shell脚本上git仓库管理,但拉取后,上l

Redis中Hash从使用过程到原理说明

《Redis中Hash从使用过程到原理说明》RedisHash结构用于存储字段-值对,适合对象数据,支持HSET、HGET等命令,采用ziplist或hashtable编码,通过渐进式rehash优化... 目录一、开篇:Hash就像超市的货架二、Hash的基本使用1. 常用命令示例2. Java操作示例三

Redis中Set结构使用过程与原理说明

《Redis中Set结构使用过程与原理说明》本文解析了RedisSet数据结构,涵盖其基本操作(如添加、查找)、集合运算(交并差)、底层实现(intset与hashtable自动切换机制)、典型应用场... 目录开篇:从购物车到Redis Set一、Redis Set的基本操作1.1 编程常用命令1.2 集

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

解决docker目录内存不足扩容处理方案

《解决docker目录内存不足扩容处理方案》文章介绍了Docker存储目录迁移方法:因系统盘空间不足,需将Docker数据迁移到更大磁盘(如/home/docker),通过修改daemon.json配... 目录1、查看服务器所有磁盘的使用情况2、查看docker镜像和容器存储目录的空间大小3、停止dock

k8s中实现mysql主备过程详解

《k8s中实现mysql主备过程详解》文章讲解了在K8s中使用StatefulSet部署MySQL主备架构,包含NFS安装、storageClass配置、MySQL部署及同步检查步骤,确保主备数据一致... 目录一、k8s中实现mysql主备1.1 环境信息1.2 部署nfs-provisioner1.2.

idea npm install很慢问题及解决(nodejs)

《ideanpminstall很慢问题及解决(nodejs)》npm安装速度慢可通过配置国内镜像源(如淘宝)、清理缓存及切换工具解决,建议设置全局镜像(npmconfigsetregistryht... 目录idea npm install很慢(nodejs)配置国内镜像源清理缓存总结idea npm in

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

idea突然报错Malformed \uxxxx encoding问题及解决

《idea突然报错Malformeduxxxxencoding问题及解决》Maven项目在切换Git分支时报错,提示project元素为描述符根元素,解决方法:删除Maven仓库中的resolv... 目www.chinasem.cn录问题解决方式总结问题idea 上的 maven China编程项目突然报错,是

在Ubuntu上打不开GitHub的完整解决方法

《在Ubuntu上打不开GitHub的完整解决方法》当你满心欢喜打开Ubuntu准备推送代码时,突然发现终端里的gitpush卡成狗,浏览器里的GitHub页面直接变成Whoathere!警告页面... 目录一、那些年我们遇到的"红色惊叹号"二、三大症状快速诊断症状1:浏览器直接无法访问症状2:终端操作异常