引言

做.NET开发的话,想必大家对SQLHelper.cs这个类都不会陌生。很早之前微软就发布了SQLHelper.cs,如果想要了解它的详细信息可以参考我的另一篇博客:http://blog.csdn.net/u013201439/article/details/50700111。
SQLHelper.cs类中的方法有很多,刚接触的话会感觉无从下手,不知道从哪儿看起,今天的文章主要介绍SQLHelper类的方法,然后分析整理一下。


说明

SQLHelper.cs文件中包含了两个类,分别是SqlHelperSqlHelperParameterCache

//
public sealed class SqlHelper{}
public sealed class SqlHelperParameterCache{}

这两个类前面都用了sealed修饰符来修饰,表示其是一个密封类,不能作为基类,不能为其他类所继承。

SqlHelper 类提供了一组静态方法,可以用来向 SQL Server 数据库发出许多各种不同类型的命令。

SqlHelperParameterCache 类提供命令参数缓存功能,可以用来提高性能。该类由许多 Execute 方法(尤其是那些只运行存储过程的重写方法)在内部使用。数据访问客户端也可以直接使用它来缓存特定命令的特定参数集。

这次我们把SqlHelperParameterCache先放到一边,来分析SqlHelper类。

方法

SqlHelper

私有方法有四个,AssignParameterValues方法有一个重载:

AttachParameters:添加参数数组到指定的SqlCommand中
AssignParameterValues:为SqlParameters(参数)数组赋值
PrepareCommand:用于对SqlCommand(命令)的属性(如连接、事务环境等)进行初始化。

公有方法有十三个:这当中每个查询数据库的方法用到了大量的重载,每个方法用到了八个左右的重载。

ExecuteNonQuery

此方法用于执行不返回任何行或值的命令。这些命令通常用于执行数据库更新,但也可用于返回存储过程的输出参数。

ExecuteDataset

此方法返回DataSet对象,该对象包含由某一命令返回的结果集。

ExecuteReader

此方法用于返回SqlDataReader对象,该对象包含由某一命令返回的结果集。

ExecuteScalar

此方法返回一个值。该值始终是该命令返回的第一行的第一列。

ExecuteXmlReader

此方法返回 FOR XML 查询的 XML 片段。

FillDataset

此方法向DataSet填充数据。

UpdateDataset

此方法用于执行向DataSet增、删、改的命令。

CreateCommand

此方法用于创建SqlCommand。

分析

下面我们以ExecuteNonQuery()方法为例来分析下:

我们上面看到的是ExecuteNonQuery()的九个重载方法,其中前三个是准备查询,中间三个是执行查询,后面三个则是用于SQL事务查询。再细分,2-1执行的是无参数的SQL语句,而2-2执行的是包含参数数组的SQL语句(参数数组可以为空),2-3执行的则是无返回值的存储过程。实际上,1-1和1-3重载是为了方便无参数的SQL语句,而1-3和2-3重载只是为了方便调用存储过程,他们的本质还是和1-2和2-2一样。下面是针对重载方法的一些简单使用。

下面我们会使用ExecuteNonQuery来执行带参数的SQL语句,可以通过F11来逐语句来查看执行过程,会有助于我们理解SQLHelper类的使用。

#region RegisterUser 注册用户/// <summary>/// 注册用户/// </summary>/// <param name="userinfo">userinfo实体</param>/// <returns>注册成功返回True,失败返回False</returns>public bool RegisterUser(JFEntity.UserInfo userinfo){string sql = @"INSERT INTO T_User VALUES(@userID,@userName,@userSex,@userPassword,@userLevel)";SqlParameter[] sqlparamter = new SqlParameter[] {new SqlParameter("@userID", SqlDbType.Int),new SqlParameter("@userName", SqlDbType.Char,30),new SqlParameter("@userSex", SqlDbType.Char,6),new SqlParameter("@userPassword", SqlDbType.Char,16),new SqlParameter("@userLevel", SqlDbType.Char,8),};sqlparamter[0].Value = userinfo.userID;sqlparamter[1].Value = userinfo.userName;sqlparamter[2].Value = userinfo.userSex;sqlparamter[3].Value = userinfo.userPassword;sqlparamter[4].Value = userinfo.userLevel;int result = SqlHelper.ExecuteNonQuery(SqlHelper.connectionString, CommandType.Text, sql, sqlparamter);if (result != 0){return true;//注册成功}else{return false;//注册失败}}#endregion

小结

我们常用到的方法有:
ExecuteNonQuery()
ExecuteDataset()
ExecuteReader()
ExecuteScalar()

参考资料:
sqlhelper 使用指南
SqlHelper类中文注释和使用方法

SQLHelper类方法介绍及简单使用相关推荐

  1. Matplotlib的介绍及简单操作

    Matplotlib的介绍及简单操作 1 什么是Matplotlib 是专门用于开发2D图表(包括3D图表) 以渐进.交互式方式实现数据可视化 2 为什么要学习Matplotlib 可视化是在整个数据 ...

  2. (三)AJAX基本介绍和简单实例03

    (三)AJAX基本介绍和简单实例03-----Ajax与数据库的动态应用 前台显示界面: 选择所有客户之后: 选择其中一个客户---杜森: Demo03.html代码 <html> < ...

  3. rabbitMQ消息队列 – 面板介绍及简单demo

    首先rabbit安装好之后,运维会给一个控制面板. 默认账号密码为guest 登入以后可以看到具体界面. 在此鸣谢百度翻译给予的大力支持.. ###写一个简单的demo 编写之前..虽然说可以直接用底 ...

  4. Protobuf介绍及简单使用(上)

    目录 Protobuf 介绍 优势 protobuf语法 Specifying Field Rules Data type Data name Number Protobuf注释 保留字段与标识符 s ...

  5. SQL Server中追踪器Trace的介绍和简单使用

    原文:SQL Server中追踪器Trace的介绍和简单使用 一.What is Trace? 对于SQL Profiler这个工具相信大家都不是很陌生,没用过的朋友可以在SQL Server Man ...

  6. Java Math类方法介绍之史上最全

    Java Math类方法介绍之史上最全 开发中用到了Java Math类的方法,故温习记录如下. /*** 常量*/System.out.println("------>" ...

  7. S3C2440移植linux3.4.2内核之内核框架介绍及简单修改

    文章目录 uboot启动内核分析 简单配置内核 编译内核 设置机器ID 修改晶振 移植Linux3.4.2内核其他文章链接: S3C2440移植linux3.4.2内核之内核框架介绍及简单修改 S3C ...

  8. 新颖的自我介绍_简单新颖的自我介绍范文

    简单新颖的自我介绍范文 简单新颖的自我介绍范文1 各位考官好,今天能够站在这里参加面试,有机会向各位考官请教和学习,我感到非常的荣幸.希望通过这次面试能够把自己展示给大家,希望大家记住我.我叫.... ...

  9. Quartz框架实现定时任务介绍及简单使用

    https://blog.csdn.net/bicheng4769/article/details/81097305 Quartz框架介绍及简单使用 https://www.cnblogs.com/d ...

  10. Hive第一天——Hive介绍以及简单使用

    Hive第二天--Hive介绍以及简单使用 自己的话:黑发不知勤学早,白首方悔读书迟 每天都要保持前进! 一.什么是Hive 数据库: mysql.oracle.sqlserver.DB2.sqlit ...

最新文章

  1. 2022-2028年中国导热硅胶行业市场研究及前瞻分析报告
  2. 机器视觉关键技术之图像增强技术
  3. opencv计算亮度
  4. 如何直接在github上预览html网页效果
  5. 基于数据中心废热利用的供冷、供热系统
  6. gj9 迭代器和生成器
  7. 初学java---第二课《接收控制台(console)输入的方法》
  8. 前端开发工具之jQuery
  9. 360两个html页面合并,如何用html2pdf把多个连接的PHP网页合并成一个pdf?
  10. 知识分享|日本面试常考问题+巧妙回答 ②
  11. 06. Java面向对象——更改器方法和访问器方法
  12. 中国各省名称+ 经纬度
  13. 非负矩阵分解NMF简介
  14. 计算机常温环境,计算机CPU温度70度正常吗?电脑cpu常温简介
  15. shell基础--正则表达式行列提取
  16. Android获取本机蓝牙地址
  17. 疯狂的Google之各种传说
  18. Racket编程指南——4 表达式和定义
  19. C语言+EasyX实现数字雨
  20. 基于随机森林算法的糖尿病数据集回归

热门文章

  1. flex java blazeds_使用BlazeDS实现Java和Flex通信(转载)
  2. wifi上行下行速度测试_测试网速_测试网速wifi在线测试
  3. msicuu2微软卸载工具
  4. BlackBerry Enterprise Service 10 for Android下载
  5. SIM868使用笔记
  6. 迅雷没有做错什么,只是用户不需要了
  7. cocos2dx资料汇总 - 持续更新
  8. 主流WebService框架
  9. 远比系统看图更好的图片浏览器Honeyview,Picasa
  10. c#的chart标题_c#关于chart控件的使用方法