sqlhelper类是指一个基于“.NET Framework”的数据库操作组件,组件中包含数据库操作方法;sqlHelper用于简化你重复的去写那些数据库连接sqlCommand或sqlDataReader等等。
sqlHelper是一个基于.NET Framework的数据库操作组件。组件中包含数据库操作方法。sqlHelper用于简化你重复的去写那些数据库连接(sqlConnection),sqlCommand,sqlDataReader等等。sqlHelper 封装过后通常是只需要给方法传入一些参数如数据库连接字符串,sql参数等,就可以访问数据库了,很方便。
推荐课程:C#教程。
sqlHelper.cs文件中包含了两个类,分别是sqlHelper和sqlHelperParameterCache。
// 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
FillDataset
此方法向DataSet填充数据。
UpdateDataset
此方法用于执行向DataSet增、删、改的命令。
CreateCommand
分析
下面我们以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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。