一、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 DataTableUsing 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)Tryconn.Open()adp.Fill(ds)Return ds.Tables(0)Catch ex As ExceptionReturn NothingThrow exEnd TryEnd UsingEnd Function

它的使用,就拿D层来说,当判断一个用户是否存在时,输入用户名之后,这个用户名就成为了参数,调用SqlHelper的ExecuteNonQuery()方法,通过返回的DataTable的行数是否大于0来判断此用户是否存在。

    Public Function SelectUser(ByVal user As Entity.UserInfo) As DataTable Implements IDAL.IUser.SelectUserDim strUserName As String = user.UserNameDim helper As New Helper.SqlHelperDim 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 - 1DataGridView(j, i).Value = dt.Rows(i).Item(j)Next j'DataGridView.AllowUserToAddRows = False    '如果放在这里,还是会有最后一行Next i

(2)利用绑定数据集

直接dataGridView=table

http://blog.csdn.net/liutengteng130/article/details/8643863

第二种方法显然是比第一种好很多,但为什么很多人还是要只返回DataTable的第一行数据呢?

这是因为:……^^……… 我就是不把它循环遍历出来不罢休的人,然后再去尝试第二种方法,

五、我的感悟——SqlHelper

就像设计模式一样,其实一开始并不存在什么设计模式,大加就只是在写代码啊写代码,但是需要写的代码也多了,当时会编程的人又少,就要提高写代码的效率,所以一些设计模式就出现了,面向对象的出现也是有一定的时间积累的,人们需要复用代码,又先要少写代码就能够实现要求,而且是系统软件看起来更简洁,达到高内聚低耦合的效果。如果说设计模式的出现是认识思想的升华,那SqlHelper就是人们思想的结晶。

当我用了SqlHelper的时候一开始会觉得很难,但是会慢慢的发现它的思想它的好处。人们最大的进步就是会使用工具,当有人给我们创造出了工具后我们要做的就是好好的使用工具,然后创造更好的工具给别人使用。

SqlHelper——只因为在人群中多看了你一眼相关推荐

  1. 只因,在人群中多看了你一眼 (小说)

    <p>静静置身于一帘幽梦中,低眉的思念,借何日的流云话心中凄迷?玫瑰,随风凋零,渐渐失去了归途的方向.</p> <p>--题记</p> <p> ...

  2. 只是因为在人群中多看了HoloSens下一代摄像机一“眼”

    点击上方关注我们! 只是因为在人群中多看了你一眼, 从此,智能世界中 便多了一双神奇的智能感知的"眼睛". 它让被动的传统安防 快速走向城市治理.智慧民生等广阔天地. 站在未来看未 ...

  3. 在中国人群中感染率最高的高危型HPV病毒是HPV16、HPV52和HPV58

    作者:王小乐 来源:生物医药行业动态(Biomed24) 2006年,美国默沙东的HPV疫苗加德西(Gardasil,香港叫做加卫苗)被美国FDA批准用于预防6型, 11型, 16型和18型HPV病毒 ...

  4. 目标追踪与定位学习笔记8-排斥损失:检测人群中的行人

    Repulsion Loss: Detecting Pedestrians in a Crowd 排斥损失:检测人群中的行人 论文链接:arXiv 1. 论文思路 本文通过为拥挤场景设计普通边界框回归 ...

  5. 关于图像处理技术在色盲色弱人群中的应用猜想

    2018/11/29 文章目录 2018/11/29 写在开头 色盲的原因(以红绿色盲为例) 染色体遗传 基因导致的眼部缺陷 色盲.色弱的表现形式 全色盲 红色盲 绿色盲 蓝黄色盲 全色弱 部分色弱 ...

  6. 如何成为人群中的亮点?能说会道是成功人士的共同品质

    能说会道是许多成功人士的共同品质.凭借这种能力,他们在大众面前侃侃而谈,成为焦点:凭借这种能力,他们在职场上左右逢源.拓展人脉,从同事.老板和客户身上获取商机. 曾为<财富>500强企业做 ...

  7. 掌握这几种OPPO手机拍照方式,让你在人群中脱颖而出

    我们现在拿到新手机的第一时间不是去看看这款手机的系统有多好,也不是去看看这款手机的运行内存有多大,而是打开手机上的相机软件,看看自己手机上的相机像素有多高.现在我们出去旅游不用再打上一部相机到处拍照, ...

  8. [EULAR文摘] 在总人群中监测ACPA能否预测早期关节炎

    标签: 类风湿关节炎; 抗CCP抗体; 预测因子; 病程演变 在总人群中监测ACPA能否预测早期关节炎 Verstappen SM, et al. EULAR 2015. Present ID: OP ...

  9. url 保持不变php,thinkphp3.2.3如何只改变地址url中的某一个分隔符,其它保持不变...

    今天教大家一个关于使用thinkphp3.2.3改变只改变地址url中的某一个分隔符的方法,首先大家来看看这个地址! 它的原始地址应该是/Home/Index/index/page/2.html,那我 ...

  10. [vue] 怎么使css样式只在当前组件中生效?

    [vue] 怎么使css样式只在当前组件中生效? <style scoped> </style> 个人简介 我是歌谣,欢迎和大家一起交流前后端知识.放弃很容易, 但坚持一定很酷 ...

最新文章

  1. Shell 编程快速入门
  2. Jackson ObjectMapper
  3. J2ME手游开发日记
  4. ajax如何提交多表单的值_25 HTML5表单基本控件(二)
  5. 【软件工程】构件化业务模型CBM
  6. Android 自定义下拉刷新
  7. solr7在tomcat上的部署
  8. 拓端tecdat|用RSHINY DASHBOARD可视化美国投票记录
  9. 自组织特征映射网络1
  10. 在线表单收集系统Tduck(docker篇)
  11. 利用VB2005制作颜色渐变的进度条
  12. 可拖动组件 v-drag vue
  13. 经纬度手动简单调整整位置
  14. 如何搭建企业报表管理系统?
  15. 三维地图之cesium轨迹回放(有代码)
  16. 范数(Norm)和谱半径(Spectral Radii)
  17. 6.Spring security中的rememberMe
  18. 上海计算机科学大学排名,计算机科学与技术专业大学排名
  19. 永续合约系统开发功能亮点
  20. 国家开放大学《国际经济法》第五章 世界贸易组织多边贸易体制 边学边练

热门文章

  1. ubuntu18.04播放MP4
  2. 设为首页,加入收藏兼容360/火狐/谷歌/IE等主流浏览器的代码
  3. 《深入理解Windows操作系统》笔记5
  4. window certutil查看文件md5,校验文件MD5
  5. 基于arduino的ESP32 学习笔记(四)基于AIDA64的电脑性能监控
  6. 你了解实时3D渲染吗?实时渲染软件和应用场景科普来了
  7. 计算机基础 键盘认识,电脑入门(八)、认识键盘及操作
  8. sim7020c功耗_SIM7020C NB-IoT HAT教程
  9. Android TableLayout 表格布局详解
  10. WebService框架简介