SqlHelper

SqlHelperSqlHelper

大家好,又见面了,我是你们的朋友全栈君。

    在机房重构的过程中,几乎所有调用D层的过程中,都需要连接数据库,如果每个功能都写一段连接的代码,这不就重复了好多吗?所以我们就可以把这些重复的代码抽象出来写到一个类中,这样就可以实现代码的复用。

我们的功能和数据库的连接大体上可以分为四种情况:

SqlHelper

如何写SQL Helper类:

1.有参数的查询:

方法一:

'执行有参的查询操作
Public Function ExecSelect(ByVal cmdText As String, ByVal cmdType As CommandType, ByVal paras As SqlParameter()) As DataTable
    Using conn As New SqlConnection(strConnection)
        Dim cmd As SqlCommand = conn.CreateCommand()
        Dim adp As SqlDataAdapter
        Dim ds As New DataSet
        cmd.CommandText = cmdText
        cmd.CommandType = cmdType
        cmd.Parameters.AddRange(paras)
        adp = New SqlDataAdapter(cmd)
        Try
            conn.Open()
            adp.Fill(ds)
            Return ds.Tables(0)
        Catch ex As Exception
            Return Nothing
            Throw ex
        End Try
    End Using
End Function

方法二:

'执行有参的查询操作
Public Function ExecSelect(ByVal cmdText As String, ByVal cmdType As CommandType, ByVal paras As SqlParameter()) As DataTable
        Dim sqlAdapter As SqlDataAdapter
        Dim dt As New DataTable
        Dim ds As New DataSet

        cmd.CommandText = cmdText
        cmd.CommandType = cmdType
        cmd.Parameters.AddRange(paras)
        sqlAdapter = New SqlDataAdapter(cmd)
        cmd.Connection = conn
        Try
            conn.Open()
            sqlAdapter.Fill(ds)
            dt = ds.Tables(0)
            cmd.Parameters.Clear()
            Catch ex As Exception
            MsgBox(ex.Message, , "数据库操作")
        Finally
            Call CloseConn(conn)
            Call CloseCmd(cmd)
        End Try
        Return dt
 End Function
 '关闭连接
 Public Shared Sub CloseConn(ByVal conn As SqlConnection)
        If (conn.State <> ConnectionState.Closed) Then
            conn.Close()
            conn = Nothing
        End If
 End Sub
 '释放命令
 Public Shared Sub CloseCmd(ByVal cmd As SqlCommand)
        If Not IsNothing(cmd) Then
            cmd.Dispose()
            cmd = Nothing
        End If
 End Sub

    

    对比上面两种方法,都可以实现对数据库的查询操作,方法一使用using连接池,在使用完成后就会自动关闭数据库连接,然而第二种方法定义了关闭数据库的方法,每次都需要调用CloseConn()方法才能关闭数据库连接,这样在程序运行时,又是就会出现数据库未关闭的错误,所以个人认为使用using连接池比较好。

2.无参数的查询:

'执行无参的查询操作
Public Function ExecSelectNo(ByVal cmdText As String, ByVal cmdType As CommandType) As DataTable
    Using conn As New SqlConnection(strConnection)
        Dim cmd As SqlCommand = conn.CreateCommand()
        Dim adp As SqlDataAdapter
        Dim ds As New DataSet
        cmd.CommandText = cmdText
        cmd.CommandType = cmdType
        adp = New SqlDataAdapter(cmd)
        Try
            conn.Open()
            adp.Fill(ds)
            Return ds.Tables(0)
        Catch ex As Exception
            Return Nothing
            Throw ex
        End Try
    End Using
End Function

3.有参数的增删改:

    Public Function ExecAddDelUpdate(ByVal cmdText As String, ByVal cmdType As CommandType, ByVal paras As SqlParameter()) As Integer
        Using conn As New SqlConnection(strConnection)
            Dim cmd As SqlCommand = conn.CreateCommand
            cmd.CommandText = cmdText
            cmd.CommandType = cmdType
            cmd.Parameters.AddRange(paras)
            Try
                conn.Open()
                Return cmd.ExecuteNonQuery
            Catch ex As Exception
                Return 0
                Throw ex
            End Try
        End Using
    End Function

4.无参数的增删改:

'无参的增删改
Public Function ExecAddDelUpdateNo(ByVal cmdText As String, ByVal cmdType As CommandType) As Integer
    Using conn As New SqlConnection(strConnection)
        Dim cmd As New SqlCommand
        cmd.CommandText = cmdText
        cmd.CommandType = cmdType
        Try
            conn.Open()
            Return cmd.ExecuteNonQuery
        Catch ex As Exception
            Return 0
            Throw ex
        End Try
    End Using
End Function

以登录时判断用户是否存在为例,在D层调用SQLHelper

    Public Function SelectUser(enUser As Entity.UsersEntity) As DataTable Implements IDAL.IUser.SelectUser    
        Dim helper As New Helper.SqlHelper  
        Dim dt As New DataTable  
        Dim cmdText As String = "select userPassword,level from [T-Users] where userId=@userId and isOn='是'"  
        Dim sqlParams As SqlParameter() = {New SqlParameter("@userId", enUser.UserId)}  
        dt = helper.ExecSelect(cmdText, CommandType.Text, sqlParams)  
        Return dt  
    End Function 

代码很容易就可以实现,重要是一开始自己的思考。总结上面四种情况,也可以简单的分为查询和增删改两种方法,关于参数如何处理,正在研究中……

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/105761.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月24日 下午10:00
下一篇 2022年4月24日 下午10:00


相关推荐

  • linux下ant安装和使用教程,ant安装与简单应用

    linux下ant安装和使用教程,ant安装与简单应用ant安装与简单应用1、下载ant软件包,本次下载的是apache-ant-1.9.6-bin.tar.gz2、传到Linux服务器上,我传到/usr/local/下3、解压缩,并创建软连接[root@localhostlocal]#tarxfapache-ant-1.9.6-bin.tar.gz[root@localhostlocal]#ln-svapache-ant-1.9.6…

    2022年7月24日
    8
  • Gradle与Maven的区别

    Gradle与Maven的区别Java 生态体系中有三大构建工具 Ant Maven 和 Gradle 其中 Ant 是由 Apache 软件基金会维护 Maven 这个单词来自于意第绪语 犹太语 意为知识的积累 最初在 JakataTurbin 项目中用来简化构建过程 Gradle 是一个基于 ApacheAnt 和 ApacheMaven 概念的项目自动化构建开源工具 它使用一种基于 Groovy 的特定领域语言 DSL 来声明项目设置 抛弃了基于 XML 的各种繁琐配置 经过几年的发展 Ant 几乎销声匿迹 而 Maven 由于较为不灵活的配置也渐渐被遗忘 而

    2026年3月19日
    1
  • linux centos7安装netcat

    linux centos7安装netcat

    2022年2月12日
    52
  • js数组怎么删除指定元素_给数组添加一个元素的方法

    js数组怎么删除指定元素_给数组添加一个元素的方法js数组是js部分非常重要的知识,有时我们有这么个需求js数组删除指定元素,先定义一个函数来获取删除指定元素索引值,然后用js数组删除的方法,来删除指定元素即可,就两步不难,很简单。1、JS的数组对象定义一个函数,用于查找指定的元素在数组中的位置,也就是索引值,代码如下: 1 2 3 4 5 6 Array….

    2026年4月15日
    6
  • layoutSubviews触发问题

    layoutSubviews触发问题layoutSubviews在以下情况下会被调用: 1、init初始化不会触发layoutSubviews 2、addSubview会触发layoutSubviews 3、设置view的Frame会触发layoutSubviews,当然前提是frame的值设置前后发生了变化 4、滚动一个UIScrollView会触发layoutSubviews 5、旋转Screen会触发父UIView上的layo…

    2022年7月25日
    19
  • idea打包教程[通俗易懂]

    idea打包教程[通俗易懂]然后点apply/ok

    2022年10月3日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号