迟来SQLHelper
机房收费系统个人重构版敲完登陆系统之后往后敲了几个窗口,对于那些数据库连接SqlConnenction、SqlConnamd等常常敲反复的代码,之前也看过其它人的博客,这个东西不用还真不行。
SqlHelper是什么?
SqlHelper是一个基于·NETFramework的数据库操作组件。组件中包括数据库操作方法。
SqlHelper的作用?
SqlHelper用于简化你反复的去写那些数据库连接(SqlConnection),SqlCommand,SqlDataReader等等。SqlHelper封装过后一般是仅仅须要给方法传入一些參数如数据库连接字符串,SQL參数等。就能够訪问数据库了。
机房个人重构Sqlhelper代码:
’****************************************************
’文件名称:SqlHelper
’命名空间:DAL
'内容:使用SqlHelper,提供较高的数据訪问性
’功能:
’文件关系:
’作者:赵亚盟
’小组:XXX
’生成日期:2014-07-17 14:44:38
’版本号号:V1.0.0.0
’改动日志:
’版本号说明:
'****************************************************
Imports System.Data
Imports System.Data.SqlClient 'SQLServer的连接对象
Imports System.Configuration '配置文件的引用 (管理器中也要引用)
'------------------------------------------------------------------------------------------------------------------------------------------------------------------
Public Class SqlHelper Dim Connstr As String = ConfigurationManager.AppSettings("Connstr") '配置文件
Dim conn As New SqlConnection '定义连接
Dim cmd As New SqlCommand '定义命令
Public Sub New()
conn = New SqlConnection(Connstr)
End Sub
#Region "有參数的查询操作" ''' <summary>
'''运行查询操作。有參数返回datatable类型
''' </summary>
''' <param name="cmdText">须要运行语句。能够是Sql语句也能够是存储过程</param>
''' <param name="cmdType">推断Sql语句的类型,一般都不是存储过程</param>
''' <param name="paras">參数数组</param>
''' <returns>返回表</returns>
''' <remarks></remarks>
Public Function GetDataTable(cmdText As String, cmdType As String, paras As SqlParameter()) As DataTable Dim adapter As New SqlDataAdapter
Dim ds As New DataSet '定义一个适配器对象
Dim dt As New DataTable cmd.CommandText = cmdText '设置查询语句
cmd.CommandType = cmdType
cmd.Connection = conn '设置连接,全局变量
cmd.Parameters.AddRange(paras) '传入參数
adapter = New SqlDataAdapter(cmd) '实例化Adapter Try
adapter.Fill(ds) '用Adapter将Dataset填充
dt = ds.Tables(0) 'datatable为DataSet的第一个表
cmd.Parameters.Clear() '清除參数
Catch ex As Exception
MsgBox("查询失败", CType(vbOKOnly + MsgBoxStyle.Exclamation, MsgBoxStyle), "警告")
Finally
Call CloseConn(conn)
Call CloseCmd(cmd) '销毁cmd
End Try
Return dt '返回受影响的行数 End Function #End Region '------------------------------------------------------------------------------------------------------------------------------------------------------------------------
#Region "无參数的查询操作"
''' <summary>
'''运行查询操作。无參数返回datatable类型
''' </summary>
''' <param name="cmdText">须要运行语句,能够是Sql语句也能够是存储过程</param>
''' <param name="cmdType">推断Sql语句的类型,一般都不是存储过程</param>
''' <returns>返回表</returns>
''' <remarks></remarks>
Public Function GetDataTable(ByVal cmdText As String, ByVal cmdType As CommandType) As DataTable Dim adapter As New SqlDataAdapter
Dim ds As New DataSet '定义一个适配器对象
Dim dt As New DataTable cmd.CommandText = cmdText '将sql语句传给cmdsql
cmd.CommandType = cmdType '确定语句类型
cmd.Connection = conn '设置连接,全局变量
adapter = New SqlDataAdapter(cmd) '实例化Adapter Try
adapter.Fill(ds) '用Adapter将Dataset填充
dt = ds.Tables(0) 'datatable为DataSet的第一个表
Catch ex As Exception
MsgBox("查询失败", CType(vbOKOnly + MsgBoxStyle.Exclamation, MsgBoxStyle), "警告")
Finally
'销毁cmd
Call CloseConn(conn)
Call CloseCmd(cmd)
End Try
Return dt '返回受影响的行数 End Function #End Region
'----------------------------------------------------------------------------------------------------------------------------------------------------------------------
#Region "有參数的增删改"
''' <summary>
''' ///运行有參数的增删改操作,有參数则返回Boolean类型,确认是否运行成功
''' </summary>
''' <param name="cmdText">须要运行语句。能够是Sql语句也能够是存储过程</param>
''' <param name="cmdType">推断Sql语句的类型。一般都不是存储过程</param>
''' <param name="paras">參数数组</param>
''' <returns>返回Boolean类型。成功返回true,否则返回false</returns>
''' <remarks></remarks>
Public Function ExecuteNoQuery(cmdText As String, cmdType As CommandType, paras As SqlParameter()) As Boolean cmd.Parameters.AddRange(paras) '传入參数
cmd.CommandType = cmdType '确定语句类型
cmd.CommandText = cmdText '设置查询语句
cmd.Connection = conn '设置连接。全局变量 Try
conn.Open() '打开连接
Return cmd.ExecuteNonQuery() '运行增删改操作
cmd.Parameters.Clear() '清除參数
Catch ex As Exception
Return False '假设出现错误,则返回false
Finally
'关闭数据库
Call CloseConn(conn)
Call CloseCmd(cmd)
End Try End Function #End Region
'------------------------------------------------------------------------------------------------------------------------------------------------------------------------
#Region "无參数的增删改"
''' <summary>
''' ///运行增删改操作,无參返回Boolean型。确认是否运行成功
''' </summary>
''' <param name="cmdText">须要运行语句。能够是Sql语句也能够是存储过程</param>
''' <param name="cmdType">推断Sql语句的类型,一般都不是存储过程</param>
''' <returns>返回Boolean类型,成功返回true,否则返回false</returns>
''' <remarks></remarks>
Public Function ExecuteNoQuery(cmdText As String, cmdType As CommandType) As Boolean cmd.CommandType = cmdType '推断类型
cmd.CommandText = cmdText '设置查询语句
cmd.Connection = conn '设置连接 Try
conn.Open() '打开连接
Return cmd.ExecuteNonQuery() '运行增删改操作
Catch ex As Exception
Return False '假设出现错误,则返回false
Finally
'关闭数据库
Call CloseConn(conn)
Call CloseCmd(cmd)
End Try End Function #End Region Public Sub CloseCmd(ByVal cmd As SqlCommand)
'推断cmd命令是否存在。假设cmd命令不存在就销毁
If Not IsNothing(cmd) Then
cmd.Dispose()
cmd = Nothing
End If
End Sub Public Sub CloseConn(ByVal conn As SqlConnection)
'推断数据库连接对象状态是否是断开状态,,假设不是就断开
If conn.State <> ConnectionState.Closed Then
conn.Close() '关闭连接
End If
End Sub
End Class
在 SqlHelper 类中实现的方法包含:
ExecuteNonQuery。用于运行(有參数或无參数的)不返回不论什么行或值的命令。这些命令通经常使用于运行数据库(增\删\改)更新,但也可用于返回存储过程的输出參数。
ExecuteReader。此方法用于返回 SqlDataReader 对象,该对象包括由某一命令返回的结果集。
ExecuteDataset。此方法返回DataSet 对象,该对象包括由某一命令返回的结果集。
注意:在使用SqlHelper方法调用数据库存储过程时。须要获取存储过程的返回值。使用带有SSqlParameter[]參数的方法,Object[]參数的方法无法获取存储过程的返回值。
版权声明:本文博客原创文章,博客,未经同意,不得转载。
迟来SQLHelper的更多相关文章
- 不该活着的SqlHelper和DBHelper
前言: 还记得刚学ADO.NET的情景么? 还记得当年是怎么从ADO.NET被忽悠到用SqlHelper的么? 话说从入门到走上工作岗位那些年,我们就一直被纯纯地教导或引导,ADO.NET太原始,得封 ...
- SqlHelper中IN集合场景下的参数处理
我手头有个古老的项目,持久层用的是古老的ADO.net.前两天去昆明旅游,其中的一个景点是云南民族村,通过导游介绍知道了一个古老的民族——基诺族,“基”在这个族内代表舅舅,“基诺”意为“跟在舅舅后边” ...
- 支持多返回值存储过程的SqlHelper
public readonly string connStr = ConfigurationManager.ConnectionStrings["sql"].ConnectionS ...
- 微软版的SqlHelper.cs类
一,微软SQLHelper.cs类 中文版: using System; using System.Data; using System.Xml; using System.Data.SqlClien ...
- 万能的SqlHelper,麻麻再也不用担心用什么数据库了
以前只用一种数据库,倒也无所谓,但是再数据库切换的时候,发现代码差不多呀. 最初,两种数据库,大不了写两个SqlHelper,但是多了也就发现代码重用率太低了吧. 因此,下面的SqlHelper诞生了 ...
- sqlHelper做增删改查,SQL注入处理,存储值,cookie,session
一.存储值 eg:登录一个页面,在进入这个页面之前你怎么知道它登没登录呢?[在登录成功之后我们把状态保存起来] 存储值得方式有两种,一种是cookie,一种是session 1.1区别: 代码: if ...
- sqlHelper做增删改查
1.把数据库里面的数据显示出来 sqlHelper怎么用:[网上可以下载,需要可以找楼主要] 1.拷贝到项目,修改它的命名空间等于当前项目名称 2.数据库的连接信息,用户名,密码,登录方式等 < ...
- SqlHelper类
using System; using System.Collections; using System.Collections.Generic; using System.Data; using S ...
- .net C# SqlHelper for Oracle
适用于Oracle的sqlhelper 需要使用ODP.Net,引用Oracle.DataAccess.dll 推荐安装ODAC 代码如下: using System; using System.Co ...
随机推荐
- iOS开发关于AppStore程序的上传流程
主要内容: 1.创建唯一标示符App ID(前提是你的程序在真机上测试没有任何问题) 2.申请发布证书 3.申请发布描述文件 4.iTunes Connect创建App并填写信息 5.选择证书编译打包 ...
- Android 开发中eclipse 下 DDMS 视图中 sdcard 中文件导入的处理
首先需要说明下,这里说的sdcard的权限并不是指在Android application程序中设置sdcard的权限读 取问题.而是指在DDMS看到的目录下的那个sdcard目录的权限问题. ...
- BIOS和CMOS的联系与区别
BIOS为何物? BIOS就是(Basic Input/Output System,基本输入/输出系统的缩写)在电脑中起到了最基础的而又最重要的作用.是电脑中最基础的而又最重要的程序.把这一段程序放在 ...
- 数论(容斥原理)hdu-4509-The Boss on Mars
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4059 题目大意: 给一个n,求1~n中与n互质的数的4次方的总和. 解题思路: 容斥原理.逆元.公式 ...
- 多线程之线程通信条件Condition
Condition是Locks锁下的还有一种线程通信之间唤醒.堵塞的实现.它以下的await,和signal可以实现Object下的wait,notify和notifyAll的所有功能,除此之外改监视 ...
- 使用webview来查看网站
1.权限 <uses-permission android:name="android.permission.INTERNET"/> 2.视图 <Relative ...
- BZOJ 4057: [Cerc2012]Kingdoms( 状压dp )
状压dp.... 我已开始用递归结果就 TLE 了... 不科学啊...我dp基本上都是用递归的..我只好改成递推 , 刷表法 将全部公司用二进制表示 , 压成一个数 . 0 表示破产 , 1 表示没 ...
- DP HDIJ1421 搬宿舍
Problem Description 搬寝室是很累的,xhd深有体会.时间追述2006年7月9号,那天xhd迫于无奈要从27号楼搬到3号楼,因为10号要封楼了.看着寝室里的n件物品,xhd开始发呆, ...
- 利用java concurrent 包实现日志写数据库的并发处理
一.概述 在很多系统中,往往需要将各种操作写入数据库(比如客户端发起的操作). 最简单的做法是,封装一个公共的写日志的api,各个操作中调用该api完成自己操作日志的入库.但因为入数据库效率比较低,如 ...
- 基于visual Studio2013解决C语言竞赛题之0803报数
题目