• 技术文章 >后端开发 >C#.Net教程

    sqlhelper类是什么

    (*-*)浩(*-*)浩2020-09-15 13:41:04原创2883

    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()方法为例来分析下:

    C#Sql.jpg

    我们上面看到的是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类是什么的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:sqlhelper
    上一篇:c语言精通了能干什么? 下一篇:c#如何防止sql注入?
    PHP编程就业班

    相关文章推荐

    • c#中SqlHelper封装SqlDataReader的方法• C#实现操作MySql数据层类MysqlHelper实例• 关于.net C# Sql数据库SQLHelper类实例代码• C#编写SqlHelper类的使用详解

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网