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

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

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

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

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

sysmain服务可以禁用吗? 电脑sysmain服务关闭后的影响与操作指南

《sysmain服务可以禁用吗?电脑sysmain服务关闭后的影响与操作指南》在Windows系统中,SysMain服务(原名Superfetch)作为一个旨在提升系统性能的关键组件,一直备受用户关... 在使用 Windows 系统时,有时候真有点像在「开盲盒」。全新安装系统后的「默认设置」,往往并不尽编