基于ADO.NET的SqlHelper类

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基于ADO.NET的SqlHelper类相关的知识,希望对你有一定的参考价值。

1.使用Connection连接数据库的步骤:

(1).添加命名空间 System.Data.SqlClient(注意:初学者经常会忘记)

(2)定义连接字符串。连接SQL Server 数据库时:

        server=服务器名;database=数据库名;uid=用户名;pwd=密码;例如:要连接本机上的StudentManagement数据库,用户名为sa,密码为111

string connString="server=.;database=StudentManagement;uid=sa;pwd=111;"

(3).创建Connection对象:

            SqlConnection connection=new SqlConnection(connSting);

(4).打开数据库:

            connection.Open();

(5).对数据库操作完毕后关闭数据库连接

            connection.Close();

2.Command对象:

(1).command对象可以用来对数据库发出具体的操作指令,例如对数据库的查询、增加、修改、删除

(2).创建Command对象,并设置它的属性:

          SqlCommand command =new SqlCommand();

          command.Connection=connection;

          command.CommandText=sqlQuery(sqlQuery为查询语句);

(3).Command对象的主要方法:

ExecuteNonQuery:执行后不返回任何行,对于update、insert、delete语句,返回影响的行数对于其他类型的语句,返回值为-1

ExecuteReader:执行查询语句,返回DataReader对象

ExecuteScalar:执行查询,并返回查询结果的第一行第一列,忽略其他列或行

ExecuteXmlreader:将CommandText发送到Connection并生成一个XmlReader

3.DataReader对象:

(1).DataReader对象可以从数据库中一只读、只进的方式查询数据,每次的操作只有一个记录保存在内存中

(2).DataReader对象的主要方法:

Read:读取下一条数据

Close:关闭DataReader对象

(3).使用DataReader提取数据的步骤:

     (a).建立与数据库的连接并打开

     (b).创建一个Command对象

     (c).从Command对象中创建DataReader对象

     (d).使用DataReader读取并显示

                 可以使用一个循环利用Read方法便利数据库中行的信息,如果要获取该行中某列的值,只需要使用"["和"]"运算符就可以了

     (e).分别关闭DataReader对象和数据库的连接

技术分享

技术分享

下面下一个简单的ADO.NET帮助类

 public static class ADOSQLHelper
    {
        private static readonly string constr = ConfigurationManager.ConnectionStrings["Master"].ConnectionString;
        /// <summary>
        ///执行增删改
        /// </summary>
        /// <param name="sql"></param>
        /// <param name="pms"></param>
        /// <returns></returns>
        public static int ExecuteNoneQuery(string sql, params SqlParameter[] pms)
        {
            using (SqlConnection con = new SqlConnection(constr))
            {
                using (SqlCommand cmd = new SqlCommand(sql, con))
                {
                    if (pms != null)
                    {
                        cmd.Parameters.AddRange(pms);
                    }
                    con.Open();
                    return cmd.ExecuteNonQuery();
                }
            }
        }
        /// <summary>
        /// 如果SqlParameter为空则转换为DBNull
        /// </summary>
        /// <param name="obj"></param>
        /// <returns></returns>
        static public object SqlNull(object obj)
        {
            if (obj == null)
            {
                return DBNull.Value;
            }        
            return obj;
        }
        /// <summary>
        /// 如果是DBNULL则转换成null
        /// </summary>
        /// <param name="obj"></param>
        /// <returns></returns>
        static public object DBNullToNull(object obj)
        {
            if (obj == DBNull.Value)
            {
                return null;
            }
            return obj;
        }

        /// <summary>
        /// 返回datatable
        /// </summary>
        /// <param name="sql"></param>
        /// <param name="pms"></param>
        /// <returns></returns>
        public static DataTable ExecuteDataTable(string sql,params SqlParameter[] pms)
        {
            DataTable dt = new DataTable();
            using (SqlDataAdapter adapter = new SqlDataAdapter(sql, constr))
            {
                if (pms != null)
                {
                    adapter.SelectCommand.Parameters.AddRange(pms);
                }
                adapter.Fill(dt);
            }
            return dt;
        }
        /// <summary>
        /// 返回单个值
        /// </summary>
        /// <param name="sql"></param>
        /// <param name="pms"></param>
        /// <returns></returns>
        public static object ExecuteScalar(string sql, params SqlParameter[] pms)
        {
            using (SqlConnection con = new SqlConnection(constr))
            {
                using (SqlCommand cmd = new SqlCommand(sql, con))
                {
                    if (pms != null)
                    {
                        cmd.Parameters.AddRange(pms);
                    }
                    con.Open();
                    return cmd.ExecuteScalar();
                }
            }
        }

    }

 

以上是关于基于ADO.NET的SqlHelper类的主要内容,如果未能解决你的问题,请参考以下文章

ADO.NET,数据库N万条数据操作

SqlHelper中IN集合场景下的参数处理

快速拥有各种数据访问SqlHelper

011.EF实体框架(入门)

请教C#/.net高手,用ado.net访问mysq与访问sqlserver的区别主要在哪些地方?

NET Core 实战 Dapper 扩展数据访问