封装几个操作数据库的方法SqlHelper

将常用的方法ExecuteNonQuary、ExecuteScalar、ExecuteReader和ExecuteAdapter的使用封装成方法,具如下

  1. 首先在App.config的xml文件里写上要连接的字符串,比如: <connectionStrings> <add connectionString="Data source=Graph;Initial catalog=中国省市;Integrated Security=true" name="PC" /> </connectionStrings>。
  2. 然后开始封装各个方法。新建一个cs文件,命名SqlHelper。首先获取连接字符串readonly static string constr = ConfigurationManager.ConnectionStrings["PC"].ConnectionString;因为这个连接字符串只在本文件中使用,所以可以加修饰符readonly
  3. 封装ExecuteNonQuary:方法要封装成静态方法。代码附在后面,这里要说的是,需要对其传一个可变参数params SqlParameter[]。方法中一定要对其判断,因为这个参数的空值和null是不一样的,所以一定要判断是否为null。
  4. 封装ExecuteScalar:大体上和ExecuteNonQuary一样
  5. 封装ExecuteReader:因为这个方法涉及到连接池的问题。所以和以上的两种方法有一定的差别,放一段代码。在这里创建连接对象的时候不能using起来,using被翻译成try  {  }finally { },在返回cmd.ExecuteReader的时候不能把连接关了,所以不能将SqlConnection conn = new SqlConnection(constr);给using起来。如果部using起来,那每次调用这个方法都会有一个对象放在连接池里面,所以可以在返回的cmd.ExecuteReader里面写上一个重载cmd.ExecuteReader(System.Data.CommandBehavior.CloseConnection);这样在返回的后关闭reader的同时将conn这个连接对象给关闭。由于创建连接对象的时候没有using起来,所以在返回的时候可能报异常,因此要将打开连接和返回这两条语句给try起来。
    public static SqlDataReader ExecuteReader(string sql, params SqlParameter[] pms)
            {
                SqlConnection conn = new SqlConnection(constr);
                using (SqlCommand cmd = new SqlCommand(sql, conn))
                {
                    if (pms != null)
                    {
                        cmd.Parameters.AddRange(pms);//如果有其他的参数 就添加进去
                    }
                    try
                    {
                        conn.Open();
                        return cmd.ExecuteReader(System.Data.CommandBehavior.CloseConnection);//调用完关闭reader的时候,把连接对象也关掉
                    }
                    catch
                    {
                        conn.Close();
                        conn.Dispose();
                        throw;
                    }
                }
    
            }

  6. 最后加一个ExecuteAdapter的方法。返回的类是DataTable的类型。思路和上面的一样。
  7. 代码如下
    using System;
    using System.Collections.Generic;
    using System.Configuration;
    using System.Data.SqlClient;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using 用treeview实现省市联动;
    
    namespace SqlHelper的封装
    {
        public static class SqlHelper
        {
            //1实现增删改ExecuteNonQuary
            //ConfigurationManager 
            readonly static string constr = ConfigurationManager.ConnectionStrings["PC"].ConnectionString;
            public static int ExecuteNonQuary(string sql, params SqlParameter[] pms)
            {
    
                using (SqlConnection conn = new SqlConnection(constr))
                {
                    using (SqlCommand cmd = new SqlCommand(sql, conn))
                    {
                        if (pms != null)
                        {
                            cmd.Parameters.AddRange(pms);
                        }
                        conn.Open();
                        return cmd.ExecuteNonQuery();
                    }
                }
            }
    
            //2实现查询,返回一个结果ExecuteScalar
            public static object ExecuteScalar(string sql, params SqlParameter[] pms)
            {
                using (SqlConnection conn = new SqlConnection(constr))
                {
                    using (SqlCommand cmd = new SqlCommand(sql, conn))
                    {
                        if (pms != null)
                        {
                            cmd.Parameters.AddRange(pms);
                        }
                        conn.Open();
                        return cmd.ExecuteScalar();
                    }
                }
            }
            //3实现查询返回多条记录ExecuteReader
            public static SqlDataReader ExecuteReader(string sql, params SqlParameter[] pms)
            {
                SqlConnection conn = new SqlConnection(constr);
                using (SqlCommand cmd = new SqlCommand(sql, conn))
                {
                    if (pms != null)
                    {
                        cmd.Parameters.AddRange(pms);//如果有其他的参数 就添加进去
                    }
                    try
                    {
                        conn.Open();
                        return cmd.ExecuteReader(System.Data.CommandBehavior.CloseConnection);//调用完关闭reader的时候,把连接对象也关掉
                    }
                    catch
                    {
                        conn.Close();
                        conn.Dispose();
                        throw;
                    }
                }
                
            }
            //4 添加方法ExecuteDataTable
            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;
            }
        }
    }
    

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值