[SqlServer数据库]封装SqlHelper

本文介绍如何封装SQLHelper类以简化数据库操作,包括执行增删改(ExecuteNonQuery)、查询单个值(ExecuteScalar)及多行多列(ExecuteReader)。通过静态连接字符串和参数化查询提高代码安全性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

封装SqlHelper类,为类库做准备


  执行增(insert) 删(delete) 改(update)
  ExecuteQuery()


  需要返回一个单个的值
  ExecuteScalar()


  需要查询多行多列
  ExecuteReader()
  
  
  ReadOnly修饰的变量只能在初始化和构造函数时赋值,其余时候只能读不能改
  添加 新建项 应用程序配置文件 App.config
  

创建一个SqlHelper类

 

静态连接字符串

private static readonly string conStr = ConfigurationManager.ConnectionStrings["mssalserver"].ConnectionString;

放在新建应用程序文件中

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <startup> 
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.6.1" />
    </startup>
</configuration>

 

1.

//1.执行增(insert) 删(delete)改(update)的方法  ExecuteNonQuery()
        public static int ExecuteNonQuery(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();

                }
            }


        }
 //2.查询返回单个值的方法  ExecuteScalar()
        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();

                }
            }


        }
//3.执行查询 返回多行 多列的方法 ExecuteReader()
        public static SqlDataReader ExecuteReader(string sql, params SqlParameter[] pms)
        {
            //可变参数????
            SqlConnection con = new SqlConnection(conStr);
            
                using (SqlCommand cmd = new SqlCommand(sql, con))
                {
                    if (pms != null)
                    {
                        cmd.Parameters.AddRange(pms);

                    }
                try
                {
                    con.Open();
                    return cmd.ExecuteReader(System.Data.CommandBehavior.CloseConnection);
                    //使用枚举参数,表示将来使用完毕SqlDataReader之后,在关闭reader同时,在SqlDataReader内部会将相关联的Connection对象也关闭掉
                }
                finally
                {
                    con.Close();
                    con.Dispose();
                }
                }
            


        }

    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值