VB.NET版机房收费系统---SqlHelper
SqlHelper,最早接触这个词儿的时候,好像是13年的暑假,那个夏天来的比往年来的稍晚一些,呵呵,sqlhelper,翻译成中文就是数据库助手,帮手。百度百科这样对她进行阐述:
SqlHelper是一个基于.NET Framework的数据库操作组件。组件中包括数据库操作方法。SqlHelper用于简化我们反复的去写那些数据库连接(SqlConnection),SqlCommand,SqlDataReader等等。SqlHelper 封装过后一般是仅仅须要给方法传入一些參数如数据库连接字符串,SQL參数等,就能够訪问数据库了,非常方便!
但是,好好的,我们为什么要用SqlHlper?我想百度百科上的解释已经非常清楚非常明确了,SqlHlper是在D层中的代码抽象出来的,那D层中什么样的代码才干抽象出来?原来啊,就是把那些对数据库进行增删改查的操作,存储过程及程序集等中同样的代码抽象出来!
在 SqlHelper 类中实现的方法包含:
ExecuteNonQuery。此方法用于运行(有參数或无參数的)不返回不论什么行或值的命令。这些命令通经常使用于运行数据库(增\删\改)更新,但也可用于返回存储过程的输出參数。
ExecuteReader。此方法用于返回 SqlDataReader 对象,该对象包括由某一命令返回的结果集。
ExecuteDataset。此方法返回 DataSet 对象,该对象包括由某一命令返回的结果集。
以下是SqlHelper的详细实现:
Imports System.Data.SqlClient
Imports System.Configuration
Public Class SqlHelper
'定义连接字符串
Dim strConnection As String = System.Configuration.ConfigurationSettings.AppSettings("strConnection")
'定义连接
Dim conn As SqlConnection
'定义命令
Dim cmd As SqlCommand
'初始化连接对象
Public Sub New()
conn = New SqlConnection(strConnection)
End Sub
'/// <summary>
'/// depiction:<有參数的非查询的操作>
'/// </summary>
'/// <param name="<strText>"><增删改语句或者存储过程></param>
'/// <param name="<cmdType>"><命令类型文本或者存储过程></param>
'/// <param name="<sqlParameter>"><參数数组></param>
'/// <returns>
'/// <返回布尔值>
'/// </returns> Public Function ExecuteNonQuery(ByVal strText As String, ByVal cmdType As CommandType, ByVal sqlParameter As SqlParameter()) As Boolean
Dim cmd As New SqlCommand '定义命令
cmd.CommandText = strText 'sql语句或存储过程名字
cmd.CommandType = cmdType '命令类型是StoredProcedure时,调用存储过程,一般为CommandText
cmd.Connection = conn '连接数据库 cmd.Parameters.AddRange(sqlParameter) '传參
Dim flag As Boolean = False '定义返回值 Try
conn.Open() '打开数据库连接
flag = cmd.ExecuteNonQuery
cmd.Parameters.Clear()
Catch ex As Exception
flag = False
Finally
Call CloseConnection(conn) '关闭数据库连接
Call CloseCmd(cmd)
End Try
Return flag
End Function '/// <summary>
'/// depiction:<获取一个带參数的查询结果阅读器>
'/// </summary>
'/// <param name="<strText>"><增删改语句或者存储过程></param>
'/// <param name="<cmdType>"><命令类型文本或者存储过程></param>
'/// <param name="<sqlParameter>"><參数数组></param>
'/// <returns>
'/// <返回布尔值>
'/// </returns>
Public Function ExecuteReader(ByVal strText As String, ByVal cmdType As CommandType, ByVal sqlParameter As SqlParameter()) As Boolean
Dim cmd As New SqlCommand
Dim reader As SqlDataReader
cmd.CommandText = strText 'sql语句或存储过程名字
cmd.CommandType = cmdType '命令类型是StoredProcdeure时,调用存储过程,一般为CommandText
cmd.Connection = conn cmd.Parameters.AddRange(sqlParameter) '传參
Dim flag As Boolean = False '定义返回值 Try
conn.Open()
reader = cmd.ExecuteReader
flag = reader.Read()
cmd.Parameters.Clear()
Catch ex As Exception
flag = False
Finally
Call CloseConnection(conn)
Call CloseCmd(cmd)
End Try
Return flag
End Function '/// <summary>
'/// depiction:<获取一个带參数的查询DataTable结果集>
'/// </summary>
'/// <param name="<strText>"><增删改语句或者存储过程></param>
'/// <param name="<cmdType>"><命令类型文本或者存储过程></param>
'/// <param name="<sqlParameter>"><參数数组></param>
'/// <returns>
'/// <返回DataTable>
'/// </returns>
Public Function ExecuteReaderTable(ByVal strText As String, ByVal cmdType As CommandType, ByVal sqlParameter As SqlParameter()) As DataTable
Dim cmd As New SqlCommand '定义命令
Dim dataAdapter As New SqlDataAdapter '定义一个适配器对象
Dim dst As New DataSet
Dim dt As New DataTable cmd.CommandText = strText 'sql语句或存储过程名字
cmd.CommandType = cmdType '命令类型是StoredProcdeure时,调用存储过程,一般为CommandText
cmd.Connection = conn '连接数据库 cmd.Parameters.AddRange(sqlParameter) '传參
Try
conn.Open()
dataAdapter.SelectCommand = cmd
dataAdapter.Fill(dst)
dt = dst.Tables(0)
Catch ex As Exception
Call CloseConnection(conn)
Call CloseCmd(cmd)
End Try
Return dt
End Function
'/// <summary>
'/// depiction:<获取上机人数>
'/// </summary>
'/// <param name="<strText>"><增删改语句或者存储过程></param>
'/// <param name="<cmdType>"><命令类型文本或者存储过程></param>
'/// <param name="<sqlParameter>"><參数数组></param>
'/// <returns>
'/// <返回整型>
'/// </returns>
Public Function ExecuteScalar(ByVal cmdText As String, ByVal cmdType As CommandType, ByVal sqlParameter As SqlParameter()) As Integer
Dim cmd As New SqlCommand
Dim count As Integer cmd.CommandText = cmdText
cmd.CommandType = cmdType
cmd.Connection = conn cmd.Parameters.AddRange(sqlParameter)
Try
conn.Open()
count = cmd.ExecuteScalar
Catch ex As Exception
Throw New Exception(ex.Message.ToString())
Finally
Call CloseCounection(conn)
Call CloseCmd(cmd)
End Try
Return count
End Function
'/// <summary>
'/// depiction:<算取金额>
'/// </summary>
'/// <param name="<strText>"><增删改语句或者存储过程></param>
'/// <param name="<cmdType>"><命令类型文本或者存储过程></param>
'/// <param name="<sqlParameter>"><參数数组></param>
'/// <returns>
'/// <返回integer>
'/// </returns>
Public Function ExecuteScalarCash(ByVal cmdText As String, ByVal cmdType As CommandType, ByVal sqlParameter As SqlParameter()) As Decimal
Dim cmd As New SqlCommand
Dim cash As Decimal cmd.CommandText = cmdText
cmd.CommandType = cmdType
cmd.Connection = conn
cmd.Parameters.AddRange(sqlParameter) Dim i As String
Try
conn.Open()
i = cmd.ExecuteScalar.ToString() If i = "" Then
cash = 0.0
Else
cash = i
End If Catch ex As Exception
Throw New Exception(ex.Message.ToString())
Finally
Call CloseConnection(conn)
Call CloseCmd(cmd) End Try
Return cash
End Function Public Sub CloseConnection(ByVal conn As SqlConnection)
If Not IsNothing(conn.State <> ConnectionState.Closed) Then
conn.Close() '关闭连接
conn = Nothing
End If
End Sub Private Sub CloseCmd(cmd As SqlCommand)
If Not IsNothing(cmd) Then '推断是否为空
cmd.Dispose()
cmd = Nothing
End If
End Sub End Class
SqlHelper封装成一个类,为开发者选择訪问数据库的方式提供了灵活性,每种方法的重载都支持不同的方法參数,因此开发者能够确定传递连接、事务和參数信息的方式。像是打包,封装的思想完美诠释,抽离出同样的内容,使代码得到复用!
VB.NET版机房收费系统---SqlHelper的更多相关文章
- VB.NET版机房收费系统---导出Excel表格
datagridview,翻译成中文的意思是数据表格显示,使用DataGridView控件,能够显示和编辑来自不同类型的数据源的表格,将数据绑定到DataGridView控件很easy和直观,大多数情 ...
- VB.NET版机房收费系统---异常处理
异常处理,英文名为Exceptional Handling, 那时年少,还记得那年一起学习过的VB6.0的时候,常常使用ONError的错误语句.与传统VB6.0中的OnError语句相比.NET平台 ...
- VB.net版机房收费系统——结账功能实现(调错与优化)
调错部分 上一篇博客<VB.net版机房收费系统--结账功能实现(代码部分>说的是结账功能的实现,亮出了代码.是在为这篇博客做铺垫.尽管结账功能代码是借鉴的巨人的博客.可是自己比着葫芦画瓢 ...
- VB.NET版机房收费系统---七仙女之系统登录
VB.NET第一版机房收费系统,告一段落,验收的时候.问题也是大大的存在,没实用上设计模式,什么触发器.存储过程,都没实用上.看看其她小伙伴的,七层实现登录?那是什么东东,相比較我的三层而言,多了两倍 ...
- VB.NET版机房收费系统---报表
报表,即报告情况的表格,简单的说:报表就是用表格.图表等格式来动态显示数据,可以用公式表示为:"报表 = 多样的格式 + 动态的数据". 在没有计算机以前,人们利用纸和笔来记录数据 ...
- VB.NET版机房收费系统---外观层如何写
外观设计模式,<大话设计模式>第103页详细讲解,不记得这块知识的小伙伴可以翻阅翻阅,看过设计模式,敲过书上的例子,只是学习的第一步,接着,如果在我们的项目中灵活应用,把设计模式用出花儿来 ...
- VB.NET版机房收费系统---组合查询
查询的意思就是查找,寻找,指在某一个或几个地方找出自己所要的信息,假如我想搜索一下我自己写的博客,名字叫做初雪之恋,我在百度的搜索框中输入丁国华三个字,会有怎样的惊喜等着我? 啊哦,这个信息并不是我想 ...
- VB.NET版机房收费系统---外观层怎样写
外观设计模式.<大话设计模式>第103页具体解说,不记得这块知识的小伙伴能够翻阅翻阅,看过设计模式,敲过书上的样例,仅仅是学习的第一步,接着,假设在我们的项目中灵活应用,把设计模式用出花儿 ...
- VB.NET版机房收费系统—数据库设计
之前第一遍机房收费的时候,用的数据库是别人的.认知也仅仅能建立在别人的基础上,等自考中<数据库系统原理>这本书学完了之后,再去看曾经的数据库,发现数据库真的还须要进一步的优化.以下是我设计 ...
随机推荐
- 【Linux指令】使用中学习(一)
sed指令: 应用:对于大文件,比如10G的大文件,我遇到的是导出的数据库.sql文件,想要使用vim修改几乎是不可能的,用sed指令可以在不打开文件的情况下修改文件,下面是一些具体用法 删除文件特定 ...
- Oracle EBS-SQL (GL-4):从接收追溯到接收事务
SELECT row_id, creation_date, created_by, last_update_date, last_updated_by,last_update_login, note_ ...
- 3.19 外协加工(通过BOM体现加工物料总成本,非系统标准工序外协功能)
3.19.1 业务方案描述 对每一个外协加工产品定义对应的加工费项目,并将发外加工物料及加工费项目一起挂在加工后产品的BOM下(供应类型为装配拉式). 加工后产品的成本按外协BOM卷积,总成本包含 ...
- 苹果新专利详解Apple Pay和NFC工作原理
本周,美国专利商标局公布了苹果一项名为“在移动支付过程中调节NFC的方法”专利申请.专利文件中详细描述了苹果Apple Pay功能以及NFC硬件构架和工作模式. 首先,苹果在专利文件中介绍了其无接触支 ...
- QCA4002/QCA4004 为主流家电和消费电子产品推出低功耗Wi-Fi平台
美国高通公司日前宣布,其子公司高通创锐讯推出全新芯片系列,这是低功耗Wi-Fi解决方案系列的一部分,可连接组成物联网的各种设备.QCA4002和QCA4004网络平台在芯片上纳入IP堆栈及完整的网络服 ...
- Delphi判断一个文件是不是JPG图片
判断头几个字节: function IsJpegFile(FileName: string): Boolean; const RightBuf : ..] of Byte = ($FF,$D8,$FF ...
- 蓝桥杯之K好数问题
问题描述 如果一个自然数N的K进制表示中任意的相邻的两位都不是相邻的数字,那么我们就说这个数是K好数.求L位K进制数中K好数的数目.例如K = 4,L = 2的时候,所有K好数为11.13.20.22 ...
- [LeetCode][Python]Roman to Integer
# -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com'https://oj.leetcode.com/problems/roman-t ...
- 面向对象程序设计-C++_课时16子类父类关系
初始化列表 类名::类名(形参1,形参2,...形参n):数据成员1(形参1),数据成员2(形参2),...,数据成员n(形参n) { ... } 规则1,初始化列表进行数据成员的初始化 规则2,初始 ...
- uva 301 Transportation 铁路公司的阳谋 纯dfs暴力
题目比较难理解. 给出铁路的容量和站点数,以及几笔订单,要求算出如何盈利最大. 咋一看想贪心,但无法确定是最优解啊. 于是用dfs做,就两种状况,选与不选,先开一个每个站点的当前人数数组,假设要选,然 ...