机房重构之SqlHelper应用

2024-08-26 20:32
文章标签 应用 重构 机房 sqlhelper

本文主要是介绍机房重构之SqlHelper应用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

由于机房重构过程中每个功能的实现都会涉及到数据库的链接访问,代码重复率非常高,耗时耗力,还会使系统出现代码冗余,是一件非常讨人厌的工作。进而把这些重复的代码抽象成一个类,以直接调用的方式来满足需求。

SqlHelper是一个基于·NET Framework的数据库操作组件,组件中包含数据库操作方法。SqlHelper用于简化重复的去写那些数据库连接(SqlConnection),SqlCommand,SqlDataReader等等。SqlHelper 封装后通常是只需要给方法传入一些参数如数据库连接字符串、SQL参数等,就可以访问数据库了。

这是最近的知识的梳理,初次使用,总结的比较简单,欢迎斧正。

SqlHelper中有两种方法,对数据库的查询和增删改,每种方法都有有参和无参两大类:

以下是在本次机房重构中SqlHelper的代码:


Imports System.Data
Imports System.Data.SqlClient
Imports System.Configuration          '添加必要引用Public Class SqlHelper'定义变量'获得数据库链接字符串Private ReadOnly strConnection As String = ("server=192.168.24.68;Database=机房重构.NET;User=sa;Password=123456;")'设置链接Dim conn As SqlConnection = New SqlConnection(strConnection)'定义Command命令Dim cmd As New SqlCommand' <summary>    ' 执行增删改三个操作,(有参)返回值为Boolean类型,确认是否执行成功    ' </summary>    ' <param name="cmdText">需要执行语句,一般是Sql语句,也有存储过程</param>    ' <param name="cmdType">判断Sql语句的类型,一般都不是存储过程</param>    ' <param name="paras">参数数组,无法确认有多少参数</param>    ' <returns></returns>    ' <remarks></remarks>Public Function ExecAddDelUpdate(ByVal cmdText As String, ByVal cmdType As CommandType, ByVal paras As SqlParameter()) As Integer'将传入的值,分别为cmd的属性赋值cmd.Parameters.AddRange(paras)        '将参数传入cmd.CommandType = cmdType             '设置一个值,解释cmdTextcmd.Connection = conn                 '设置连接,全局变量cmd.CommandText = cmdText             '设置SQL语句Tryconn.Open()                       '打开链接Return cmd.ExecuteNonQuery()      '执行增删改操作Catch ex As ExceptionThrow                         '如果出错就抛出Finallycmd.Parameters.Clear()            '清除参数Call CloseConn(conn)Call CloseCmd(cmd)End TryEnd Function' <summary>    ' 执行增删改三个操作,(无参)    ' </summary>    ' <param name="cmdText">需要执行语句,一般是Sql语句,也有存储过程</param>    ' <param name="cmdType">判断Sql语句的类型,一般都不是存储过程</param>    ' <returns>Interger,受影响的行数</returns>    ' <remarks>2013年2月2日8:19:59</remarks>   Public Function ExecAddDelUpdateNo(ByVal cmdText As String, ByVal cmdType As CommandType) As Integer'为要执行的命令cmd赋值cmd.CommandText = cmdText               '传入查询语句cmd.CommandType = cmdType               '设置Sql语句如何解释cmd.Connection = conn                   '设置连接'执行操作Tryconn.Open()Return cmd.ExecuteNonQueryCatch ex As ExceptionReturn 0FinallyCall CloseConn(conn)Call CloseCmd(cmd)End TryEnd Function' <summary>    ' 执行查询的操作,(有参),参数不限    ' </summary>    ' <param name="cmdText">需要执行语句,一般是Sql语句,也有存储过程</param>    ' <param name="cmdType">判断Sql语句的类型,一般都不是存储过程</param>    ' <param name="paras">传入的参数</param>    ' <returns></returns>    ' <remarks></remarks> Public Function ExecSeletct(ByVal cmdText As String, ByVal cmdType As CommandType, ByVal paras As SqlParameter()) As DataTableDim sqlAdpter As SqlDataAdapter            '是 DataSet和 SQL Server之间的桥接器,用于检索和保存数据Dim dt As New DataTableDim ds As New DataSet'还是给cmd赋值cmd.CommandText = cmdText                  '设置查询语句cmd.CommandType = cmdType                  '设置Cmd对象的类型cmd.Connection = conn                      '数据库连接语句cmd.Parameters.AddRange(paras)             '传入参数sqlAdpter = New SqlDataAdapter(cmd)        '实例化适配器TrysqlAdpter.Fill(ds)                     '用adapter将dataSet填充dt = ds.Tables(0)                      'dataTable是dataSet的第一个表cmd.Parameters.Clear()                 '清除参数Catch ex As ExceptionMsgBox("查询失败", CType(vbOKOnly + MsgBoxStyle.Exclamation, MsgBoxStyle), "警告!")FinallyCall CloseCmd(cmd)                     '最后一定要释放cmdEnd TryReturn dt      '返回查到的数据End Function' <summary>    ' 执行查询的操作,(无参)    ' </summary>    ' <param name="cmdText">需要执行语句,一般是Sql语句,也有存储过程</param>    ' <param name="cmdType">判断Sql语句的类型,一般都不是存储过程</param>    ' <returns>dataTable,查询到的表格</returns>    ' <remarks></remarks>   Public Function ExecSelectNo(ByVal cmdText As String, ByVal cmdType As CommandType) As DataTableDim sqlAdapter As SqlDataAdapterDim ds As New DataSet'给cmd赋值cmd.CommandText = cmdTextcmd.CommandType = cmdTypecmd.Connection = connsqlAdapter = New SqlDataAdapter(cmd)         '实例化适配器TrysqlAdapter.Fill(ds)                      '用adapter将dataSet填充Return ds.Tables(0)                      '返回dataSet的第一个表Catch ex As ExceptionReturn NothingFinallyCall CloseCmd(cmd)                       '关闭cmdEnd TryEnd Function' <summary>    ' 关闭连接    ' </summary>    ' <param name="conn">需要关闭的连接</param>    ' <remarks></remarks>   Public Sub CloseConn(ByVal conn As SqlConnection)If (conn.State <> ConnectionState.Closed) Then  '如果没有关闭conn.Close()                                '关闭连接conn = Nothing                              '不指向原对象End IfEnd Sub' <summary>    ' 关闭命令    ' </summary>    ' <param name="cmd">需要关闭的命令</param>    ' <remarks></remarks>    Public Sub CloseCmd(ByVal cmd As SqlCommand)If Not IsNothing(cmd) Then                      '如果cmd命令还存在cmd.Dispose()                               '释放资源cmd = Nothing                               '不指向原对象End IfEnd SubEnd Class

这篇关于机房重构之SqlHelper应用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

PostgreSQL简介及实战应用

《PostgreSQL简介及实战应用》PostgreSQL是一种功能强大的开源关系型数据库管理系统,以其稳定性、高性能、扩展性和复杂查询能力在众多项目中得到广泛应用,本文将从基础概念讲起,逐步深入到高... 目录前言1. PostgreSQL基础1.1 PostgreSQL简介1.2 基础语法1.3 数据库

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

Python中yield的用法和实际应用示例

《Python中yield的用法和实际应用示例》在Python中,yield关键字主要用于生成器函数(generatorfunctions)中,其目的是使函数能够像迭代器一样工作,即可以被遍历,但不会... 目录python中yield的用法详解一、引言二、yield的基本用法1、yield与生成器2、yi

Python多线程应用中的卡死问题优化方案指南

《Python多线程应用中的卡死问题优化方案指南》在利用Python语言开发某查询软件时,遇到了点击搜索按钮后软件卡死的问题,本文将简单分析一下出现的原因以及对应的优化方案,希望对大家有所帮助... 目录问题描述优化方案1. 网络请求优化2. 多线程架构优化3. 全局异常处理4. 配置管理优化优化效果1.