您好,欢迎访问一九零五行业门户网

sqlhelper类是什么

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
此方法返回 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
以上就是sqlhelper类是什么的详细内容。
其它类似信息

推荐信息