SqlHelper——数据库小助手

SqlHelper事实上就是一个类。

早就听说过“SqlHelper”这个名词。也查过相关的资料。但还是一头雾水。当真的去实践去用它时,就会发现事实上它没那么神奇。

当敲第一个窗口的时候。功能实现了,我们就会认为非常高兴。大功告成了。但是当敲完第二个窗口、第三个窗口的时候,慢慢的就開始认为代码反复的太多了。越敲就越认为心虚。尽管设计模式学的不怎么样,但是最起码让我有了这个意识去想怎么让代码更少一些。让彼此之间的耦合度尽量降低。

在三层中,要数D层的代码相似度最高了,总结来说,也就是连接数据库。增删改查的功能。那么。我们全然能够把这部分共同的东西拿出来放在一起。这样既能降低了代码量,也非常好的做到了封装。

SqlHelper这个类里,有几个方法

在sqlhelper中,最重要的无非是那几个增删改查的方法了。

查了非常多博客,类中的方法也有非常多种,包含ExecuteNonQuery、ExecuteReader、ExecuteDataSet、ExecuteScalar、ExecuteXmlReader等。但我们并不会都用到。有的方法了解一下就好了。方法能够划分的细。但假设分的太细。就会弄的太复杂了。

我习惯把方法分的少一些。

Public Class sqlHelper
    ‘‘‘ <summary>
    ‘‘‘ 有參数的增、删、改操作
    ‘‘‘ </summary>
    ‘‘‘ <param name="cmdText"></param>
    ‘‘‘ <param name="cmdType"></param>
    ‘‘‘ <param name="paras"></param>
    ‘‘‘ <returns></returns>
    ‘‘‘ <remarks></remarks>
    Public Function ExecuteNoQuery(cmdText As String, cmdType As CommandType, paras As SqlParameter()) As Integer
        Dim ConnStr As String = System.Configuration.ConfigurationManager.AppSettings("ConnStr")
        Dim conn As SqlConnection = New SqlConnection(ConnStr)
        ‘定义一个命令对象
        Dim cmd As New SqlCommand
        cmd = New SqlCommand(cmdText, conn)   ‘budong
        cmd.CommandType = cmdType
        cmd.Parameters.AddRange(paras)
        Dim res As Integer  ‘定义一个变量用户存放返回结果

        Try
            ‘打开数据库
            If conn.State = ConnectionState.Closed Then

                conn.Open()
            End If

            res = cmd.ExecuteNonQuery()
        Catch ex As Exception
            MsgBox(ex.Message, "数据库操作")
        Finally
            ‘关闭数据库
            If conn.State = ConnectionState.Open Then
                conn.Close()
            End If
        End Try
        Return res ‘返回受影响的行数
    End Function

    ‘‘‘ <summary>
    ‘‘‘ 无參数的增、删、改操作
    ‘‘‘ </summary>
    ‘‘‘ <param name="cmdText"></param>
    ‘‘‘ <param name="cmdType"></param>
    ‘‘‘ <returns></returns>
    ‘‘‘ <remarks></remarks>
    Public Shared Function ExecuteNoQuery(cmdText As String, cmdType As CommandType) As Integer
        Dim ConnStr As String = System.Configuration.ConfigurationManager.AppSettings("ConnStr")
        Dim conn As SqlConnection = New SqlConnection(ConnStr)

        Dim cmd As New SqlCommand  ‘定义一个命令对象
        cmd.CommandType = cmdType

        cmd = New SqlCommand(cmdText, conn)
        Dim res As Integer  ‘定义一个变量用户存放返回结果
        ‘cmd.Parameters.AddRange(paras)     该方法没有參数,不用加入
        Try
            ‘打开数据库
            If conn.State = ConnectionState.Closed Then

                conn.Open()
            End If

            res = cmd.ExecuteNonQuery()
        Catch ex As Exception
            MsgBox(ex.Message, "数据库操作")
        Finally
            ‘关闭数据库
            If conn.State = ConnectionState.Open Then
                conn.Close()
            End If
        End Try
        ‘返回受影响的行数
        Return res
    End Function

    ‘‘‘ <summary>
    ‘‘‘ 有參数的查询操作
    ‘‘‘ </summary>
    ‘‘‘ <param name="cmdTxt"></param>
    ‘‘‘ <param name="cmdType"></param>
    ‘‘‘ <param name="paras"></param>
    ‘‘‘ <returns></returns>
    ‘‘‘ <remarks></remarks>
    Public Function GetDataTable(ByVal cmdTxt As String, ByVal cmdType As CommandType, ByVal paras As SqlParameter()) As DataTable
        Dim strConnStr As String = System.Configuration.ConfigurationManager.AppSettings("ConnStr")
        ‘定义一个数据库连接对象
        Dim conn As SqlConnection = New SqlConnection(strConnStr)
        ‘定义一个命令对象
        Dim cmd As New SqlCommand
        Dim adataset As DataSet
        ‘定义一个适配器对象
        Dim adaptor As SqlDataAdapter
        cmd = New SqlCommand(cmdTxt, conn)
        adaptor = New SqlDataAdapter(cmd)
        adataset = New DataSet
        cmd.CommandType = cmdType
        cmd.Parameters.AddRange(paras)
        Try
            ‘打开数据库连接
            If conn.State = ConnectionState.Closed Then
                conn.Open()

            End If
            ‘填充数据集
            adaptor.Fill(adataset)
            Return adataset.Tables(0)
        Catch ex As Exception
            MsgBox(ex.Message)
        Finally
            ‘关闭数据库连接
            If conn.State = ConnectionState.Open Then
                conn.Close()

            End If
        End Try

    End Function

    ‘‘‘ <summary>
    ‘‘‘ 无參数的查询操作
    ‘‘‘ </summary>
    ‘‘‘ <param name="cmdTxt"></param>
    ‘‘‘ <param name="cmdType"></param>
    ‘‘‘ <returns></returns>
    ‘‘‘ <remarks></remarks>
    Public Function GetDataTable(ByVal cmdTxt As String, ByVal cmdType As CommandType) As DataTable
        Dim strConnStr As String = System.Configuration.ConfigurationManager.AppSettings("ConnStr")
        ‘定义一个数据库连接对象
        Dim conn As SqlConnection = New SqlConnection(strConnStr)
        ‘定义一个命令对象
        Dim cmd As New SqlCommand
        Dim adataset As DataSet
        ‘定义一个适配器对象
        Dim adaptor As SqlDataAdapter
        cmd = New SqlCommand(cmdTxt, conn)
        adaptor = New SqlDataAdapter(cmd)
        adataset = New DataSet
        cmd.CommandType = cmdType
        ‘cmd.Parameters.AddRange(paras)  没有參数,无需加入
        Try
            ‘打开数据库连接
            If conn.State = ConnectionState.Closed Then
                conn.Open()

            End If
            ‘填充数据集
            adaptor.Fill(adataset)
            Return adataset.Tables(0)
        Catch ex As Exception
            MsgBox(ex.Message, , "数据库操作")
        Finally
            ‘关闭数据库连接
            If conn.State = ConnectionState.Open Then
                conn.Close()

            End If
        End Try

    End Function

End Class

类有了。那怎么用呢?

有了參数,不就能够调用了。

CmdTxt就是sql语句。

CommandType有三个属性:StoredProcedure(存储过程)。TableDirect(表)。text(SQL文本命令,较经常使用)。

SqlParameter属性:在写sql语句的时候我们会定义变量,SqlParameter就是用来给数据库中定义的变量传值用的。

比如:

Dim paras As SqlParameter() = {New SqlParameter("@cardno", student.cardno)}

@cardno是变量。student.cardno是实体的值。

注意:Add与AddRange的差别

Add:将指定的对象加入到……中,AddRange:向……末尾,加入数组

Add该方法每次仅仅能加入一个SqlParameter。

AddRange可加入多个SqlParameter。在群里操作时,使用AddRange代替Add。

这样。我们的SqlHelper小助手就能够帮助完好我们的代码了。遇到一个问题,不用恐惧,先把它简单化。等我们对它有了一定的理解后再去看它复杂的地方。当我们能够灵活的使用ExecuteNonQuery、ExecuteReader、ExecuteDataSet的方法后。其它的内容也就不会难倒我们了。

时间: 2024-08-27 08:39:39

SqlHelper——数据库小助手的相关文章

【软件工程】02组软件工程组队项目——课程管理小助手数据库设计文档

一.引言 1.1编写目的 数据库的表结构设计是整个项目开发中一个非常重要的环节,一个良好的数据库设计,可以提高开发效率,方便系统维护,并且为以后项目功能的扩展留下余地.我们通过书写这份文档说明,从各方面进行学生课程管理小助手系统的数据库设计规划,用它指导该系统在数据库各方面的内容,为系统开发的程序员.系统分析员提供基准文档.我们也希望通过写数据设计说明书,规范数据名称.数据范围.数据代码等.这份文档是项目小组共同作战的基础,有了开发规范.程序模块之间和项目成员之间的接口规则.数据方式,大家就有了

房屋出租小助手APP需求分析

房屋出租小助手APP是专为个人房东管理出租房而开发的APP应用,主要功能有租客管理(利用人工智能自动识别租客×××,无需人工录入),房间管理,出租管理,水电抄表管理,水电费管理,押金管理,收款管理,×××管理,财务统计,房租支付管理,上传头像,上传微信&支付宝支付码,在线升级,修改密码等功能.该系统采用Jsp技术,使用SSM框架,Mysql数据库,ajax技术及人工智能等相关技术实现. 项目开发技术:java,jsp,mysql,MyBatis,SpringMVC,jquery,ajax,jso

微信企业号企业小助手有什么用?

企业小助手是企业号下默认添加的应用,它用来向用户发送企业号的系统消息,如: a)成员关注:向微信侧推送关注成功通知,或身份验证提示语.(成员如何关注企业号?) b)二次验证:向微信侧推送二次验证提示语,提示用户回复验证信息:(二次验证的作用和流程?) c)用户状态变更:向企业应用转发用户关注/退出通知,实时监测全局用户关注情况:(用户状态变更通知有什么用?) d)分级管理员:向微信侧推送相关提示,协助分级管理员设置/重置密码.(什么是分级管理员?如何创建?设置时有哪些限制?) 注: 1)  企业

大三上学期安卓一边学一边开始做一个自己觉得可以的项目 广商小助手App 加油

这项目构思好多 一个人一步一步来 一边做一边为后面应用铺设 广商小助手APP 设计出的软件登录场景 实现(算是可以) 界面大体出来了 界面点击方面也做了很多特效 上图其实点击各颜色后会出现各种图和反应 当然还有好多东西没弄 当前时代都看脸一个不精美的软件少人用 所以多花心思 项目还在努力中>>>>>>>

COJ 3007 Mr.Yang的小助手

传送门:http://oj.cnuschool.org.cn/oj/home/problem.htm?problemID=1037 试题描述: 信息学社团已经逐渐发展壮大,成员也越来越多.现在,有n个同学有了关于信息学的问题,公务繁忙的杨老师决定派出n个小助手来帮助他们解答问题.现在问题来了,每个小助手和它对应的同学不能离的太远(要不然杨老师会觉得场面很乱…),也就是说两个人的距离不能超过杨老师的规定值Distance.同时,俩个人的中间不能隔有其他同学(要不然同学们会互相干扰的…),就是说在两

oracle数据库小总结

---数据库小总结--- 1.数据库的基本常用数据类型 ①varchar2(size)      //浮动长度字符类型:长度会改变,根据用户输入的值进行相应的长度改变,节省内存空间 ②char(size)     //固定字符长度,如果用户输入的值得长度,不够size,则系统默认用空格代替 ③number(1,2)     //数字类型,包含小数和整数(1.代表数字的总长度/位数  2.表示小数点后的长度/位数) ④date //时间类型  sysdate(系统时间) to_date('输入的时

【程序员小助手】Synergy,感受穿越屏幕之美

 内容简介 1.Synergy简介 2.Synergy安装与配置 3.附录 [程序员小助手]系列 在这个系列文章中(不定期更新),小编会把这些年(也没几年)的编程学习和工作中使用到的个人感觉非常好的软件推荐给大家,希望能够共享美好资源,使大家提高编程和办事效率. Synergy,感受穿越屏幕之美 什么?你面前有多个电脑屏幕,而你每个屏幕(或每台电脑)单独配一个鼠标和一个键盘? 什么?你在多个屏幕之间复制黏贴东西的时候还需要借助samba这样的共享软件? 什么?你只有一台电脑,只有一个屏幕?好吧

【程序员小助手】Emacs,最强编辑器,没有之一

内容简介 1.Emacs简介 2.Emacs三个平台的安装与配置 3.自动补全插件 4.小编的Emacs配置文件 5.常用快捷方式 6.和版本控制系统的配合(以SVN为例) [程序员小助手]系列 在这个系列文章中(不定期更新),小编会把这些年(也没几年)的编程学习和工作中使用到的个人感觉非常好的软件推荐给大家,希望能够共享美好资源,使大家提高编程和办事效率. Emacs,最强编辑器,没有之一 小编知道,此标题一出,肯定会遭受广大群众“诟病”,说不好还会被其他编辑器的粉丝暗地里“干掉”. 比如,V

网络小助手项目开发总结报告

网络小助手项目开发总结报告 1引言 1.1编写目的 通过一段时间后对网络小助手项目进行详细开发和测试,该项目已经基本完成.本报告旨在将项目开发过程中的经验和不足之处进行总结,为以后的团队开发活动积累经验.本报告经审核后,交由软件工程老师王老师审查. 1.2背景 说明: a.  软件项目名称:网络小助手 b.  开发者:兰梦,李金吉,马翔,赵天,胡佳奇 用户:学生 系统运行环境:windows XP/windows 7/windows 8下的通用PC 1.3参考资料 <软件工程--原理,方法与应用