SqlHelper——只因为在人群中多看了你一眼
对SQLHelper,还是有一点陌生的,但是大多数人都在使用,我就有一种想了解并使用的意愿,于是查了很多资料,发现一片不错的博客,放在下面,作为自己或读者使用的材料。
一、SqlHelper 出场
不是因为大家都在用SqlHelper所以才用,是因为连接数据库关闭数据库查询数据库的多了也就加上了SqlHelper。当你的很多需求都有一个相同的方法的时候我们没有必要完成一个需要就要写一遍代码,完成一个需求写一遍代码,这样不仅会把人累死(当然除了复制粘贴),这样的话会造成代码的重复增加了耦合,产生了冗余。为什么不把相同的代码单独拉出来封装成一个类,这样每个需求使用时只需调用这个被封装的类的相应的方法就好了。
当有多个关于数据库增删改成操作的时候就用到了SqlHelper,因为D层是直接操作数据库,完成数据库的增删改查的,所以SqlHelper是属于D层的,但是我是单独拿出来成为一层的。把D层的所有对数据库的操作方法都封装起来。分为两种操作,一种是增删改,一种是查询操作,而每种又分为有参数的和无参数的。这样减轻了D的负担,使D层不会显得太臃肿。
在做机房之前一直在看别人的博客,总是有提到SqlHelper,所以就在众博客中多看了它一眼。只因为在人群中多看了你一眼,再也不能忘掉你的容颜,在这里写下我一个人对你的情有独钟……
二、SqlHelper 用法
1、首先,它的方法
(1)为什么要分成有参数和没有参数的呢?
这就是一种思想了,当想要获取数据库的全部信息和部分信息时,需要全部信息直接给它指定查找哪个表就行,但是当要在一个表中获取一部分信息就要有查询条件,就要有参数。
(2)为什么要分为查询和增删改两种呢?
查询是要返回给用户想要查询到的信息,增删改都可以归纳为改或者更新,更新要返回给用户更新的是否成功或失败,不需要返回具体信息。所以查询返回的是DataTable类型,而更新返回受影响的行就行,当更新好一行数据就返回整数1。这就和它的返回值产生了关系,既然有相同的就要合并起来成为一个方法,这样减少冗余,使代码简单化。学了面向对象,其实就是怎么简单怎么来。
2、然后,SqlHelper的每一个方法都要有一个返回值,因为返回值的不同会造成相应调用此方法的方法也要有一样的返回值。
(1)返回DataTable
DataTable又是什么呢?
DataTable是一个临时保存数据的网络虚拟表,可以被创建和访问,当SqlHelper查询后就要返回到DataTable虚拟表中,判断它的第一行是否有数据来判断是否查到记录。
(2)返回Integer
返回受影响的行数,如果受影响的行数大于0说明查到的记录,如果为0说明没有查询到数据。如果受影响的行数大于0说明增删改操作成功,如果为0,说明操作没有成功。我们通过返回受影响的行数到B层进行逻辑判断,然后返回相应的提示给U层,这样就很好的再一条线中实现。思路清晰。
三、SqlHelper举例应用
下面就举一个返回值是DataTable型的有参数的方法。
- '方法(2)有参数的查询
- 'return DataTable 查询出的表格
- Public Function ExecuteNonQuery(ByVal cmdText As String, ByVal cmdType As CommandType, ByVal sqlParams As SqlParameter()) As DataTable
- Using conn As New SqlConnection(strConnection) '使用连接池,可以在使用完成后自动关闭连接
- Dim cmd As SqlCommand = conn.CreateCommand() '
- cmd.CommandText = cmdText '需要执行的SQL语句
- cmd.CommandType = cmdType '给出Sql语句的类型
- cmd.Parameters.AddRange(sqlParams) '参数数组,参数个数根据实际情况而定
- 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
它的使用,就拿D层来说,当判断一个用户是否存在时,输入用户名之后,这个用户名就成为了参数,调用SqlHelper的ExecuteNonQuery()方法,通过返回的DataTable的行数是否大于0来判断此用户是否存在。
- Public Function SelectUser(ByVal user As Entity.UserInfo) As DataTable Implements IDAL.IUser.SelectUser
- Dim strUserName As String = user.UserName
- Dim helper As New Helper.SqlHelper
- Dim dt As New DataTable '声明一个DataTable类型变量
- Dim cmdText As String = "select * from User_Info where UserName=@UserName" '声明并实例化需要执行的SQL语句
- Dim sqlParams As SqlParameter() = {New SqlParameter("@UserName", strUserName)} '声明并实例化参数
- dt = helper.ExecuteNonQuery(cmdText, CommandType.Text, sqlParams) '调用SqlHelper类中的ExecSelect()方法来执行查询,并获取返回值
- Return dt '返回查询结果
- End Function
四、我的SqlHelper的问题
这样就又出现了一个问题,当我们删除用户的时候,或者需要查询到多条记录显示出来的时候,虽然返回的是DataTable类型,但是它默认了返回DataTable的第一行数据,出现这样情况解决方法有两种:
(1)通过遍历思想循环查数据库中的记录,返回一条和上一次不同的记录的第一行。
例如返回某一级别的用户
- If dt.Rows.Count > 0 Then For i = 0 To dt.Rows.Count - 1 '查到内容显示
- DataGridView.Rows.Add() '一开始没有行和列,所以要添加一行和一列,避免发生错误
- For j = 0 To dt.Columns.Count - 1
- DataGridView(j, i).Value = dt.Rows(i).Item(j)
- Next j
- 'DataGridView.AllowUserToAddRows = False '如果放在这里,还是会有最后一行
- Next i
(2)利用绑定数据集
直接dataGridView=table
第二种方法显然是比第一种好很多,但为什么很多人还是要只返回DataTable的第一行数据呢?
这是因为:……^^……… 我就是不把它循环遍历出来不罢休的人,然后再去尝试第二种方法,
五、我的感悟——SqlHelper
就像设计模式一样,其实一开始并不存在什么设计模式,大加就只是在写代码啊写代码,但是需要写的代码也多了,当时会编程的人又少,就要提高写代码的效率,所以一些设计模式就出现了,面向对象的出现也是有一定的时间积累的,人们需要复用代码,又先要少写代码就能够实现要求,而且是系统软件看起来更简洁,达到高内聚低耦合的效果。如果说设计模式的出现是认识思想的升华,那SqlHelper就是人们思想的结晶。
当我用了SqlHelper的时候一开始会觉得很难,但是会慢慢的发现它的思想它的好处。人们最大的进步就是会使用工具,当有人给我们创造出了工具后我们要做的就是好好的使用工具,然后创造更好的工具给别人使用。
转自:http://blog.csdn.net/xdd19910505/article/details/28469205
SqlHelper——只因为在人群中多看了你一眼的更多相关文章
- SqlHelper——仅仅由于在人群中多看了你一眼
一.SqlHelper 出场 不是由于大家都在用SqlHelper所以才用,是由于连接数据库关闭数据库查询数据库的多了也就加上了SqlHelper.当你的非常多需求都有一个同样的方法的时候我们没有必要 ...
- 怎样取消老毛桃软件赞助商---只需在输入框中输入老毛桃官网网址“laomaotao.org”
来源:www.laomaotao.org 时间:2015-01-29 在众多网友和赞助商的支持下,迄今为止,老毛桃u盘启动盘制作工具已经推出了多个版本.如果有用户希望取消显示老毛桃软件中的赞助商,那不 ...
- thinkphp3.2.3如何只改变地址url中的某一个分隔符,其它保持不变
今天教大家一个关于使用thinkphp3.2.3改变只改变地址url中的某一个分隔符的方法,首先大家来看看这个地址! 它的原始地址应该是/Home/Index/index/page/2.html,那我 ...
- ICCV2021 |重新思考人群中的计数和定位:一个纯粹基于点的框架
论文:Rethinking Counting and Localization in Crowds:A Purely Point-Based Framework 代码:https://github ...
- 以SqlHelper为例论面向对象中封装的使用
引言: 在使用面向对象方法编写的程序中,会有一些工具类,如Utility,xxHelper等. 比如1)操作数据库的过程,一般步骤都是:1.准备数据库地址.表名等信息:2.建立连接:3.准备要执行sq ...
- testNG retry 失败的testcase只需要在xml中配置一个listener即可
问题情况 先说下问题情况,最近在做testNG与selenium集成做自动化测试的问题. 因为如果将t ...
- 以SqlHelper为例论面向对象中封装的使用(续)
上文以SqlHelper为例说明了面向对象中封装的好处,但是上文只是简单封装,考虑下面代码的情况: public static Activate GetByCode(string code) { Li ...
- eclipse打断点只进入class文件中的解决办法
内容来源 https://www.cnblogs.com/scode2/p/8671908.html#undefined 是由于对应的Java类跟编译后的class文件,没有关联上, 解决办法: 在打 ...
- 如何定义一个接口(接口Interface只在COM组件中定义了,MFC和C++都没有接口的概念)
接口是COM中的关键词,在c++中并没有这个概念.接口是一种极度的抽象.接口用在COM组件中有自己的GUID值,因此定义接口时一定要指定它的GUID值. 实际上接口就是struct,即#define ...
随机推荐
- python dlib 面部轮廓实时检测
1.dlib 实现动态人脸检测及面部轮廓检测 模型下载连接 : http://dlib.net/files/ # coding:utf-8 import cv2 import os import dl ...
- 简述--构建React项目的几种方式
前言: 构建React项目的几种方式: 构建:create-react-app 快速脚手架 构建:generator-react-webpack 构建:webpack一步一步构建 1)构建:creat ...
- js_读【javascript面向对象编程指南】笔记
写在前面: 工欲善其事,必先利其器.编程的器,是前人总结的经验,常言道站在巨人的肩膀上开发,往往比自己另辟蹊径容易的多.经验藏于书,故有书中自有颜如玉,书中自有黄金屋,我也一度认为读书要花费很多时间, ...
- 【转】linux下杀死进程
经过搜集和整理相关的Linux操作系统杀死进程的材料,在这里给大家推荐本篇文章,希望大家看后会有不少收获. 1. kill 作用:根据进程号杀死进程 用法: kill [信号代码] 进程ID 举例: ...
- Django【进阶】分页功能Pagination
项目中,我们需要很多非业务逻辑的功能,例如分页功能,而且此类功能移植性很好,可以在不同的项目中使用,所以整理好这些功能会一定程度上提高开发效率,下面是分页功能代码,使用时,可单独放在utils目录 & ...
- LeetCode 20 Generate Parentheses
Given n pairs of parentheses, write a function to generate all combinations of well-formed parenthes ...
- Django rest framework + Vue简单示例
构建vue项目参考这篇文章https://segmentfault.com/a/1190000008049815 一.创建Vue项目 修改源:npm config set registry https ...
- shellcheck 帮助你写出更好的脚本
简介 shellcheck 是一款实用的 shell脚本静态检查工具. 首先,可以帮助你提前发现并修复简单的语法错误,节约时间.每次都需要运行才发现写错了一个小地方,确实非常浪费时间. 其次,可以针对 ...
- python实战===国内很简单实用的一些开源的api以及开源项目
原创 2017年03月25日 15:40:59 标签: api / 开源项目 / app / 免费接口 声明 以下所有 API 均由产品公司自身提供,本人皆从网络获取.获取与共享之行为或有侵犯产品 ...
- linux 命令行远程登录 后台运行命令的方法
linux 命令行远程登录 后台运行命令的方法 http://blog.csdn.net/isuker/article/details/55061595 Linux 技巧:让进程在后台可靠运行的几种方 ...