C#泛型反射DBheple

反射 泛型

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Configuration;
using System.Data.SqlClient;
using System.Data;
using System.Reflection;
using Month5.Model;

namespace Month5.DAL
{
public static class DbHelper
{
//通过配置文件获取链接数据库字符串
static string connStr = ConfigurationManager.ConnectionStrings[“MonthPractice5_tenthMonth”].ConnectionString;

    /// <summary>
    /// 与数据库中增删改存储过程交互的方法
    /// </summary>
    /// <param name="storedProcedure">存储过程名称</param>
    /// <param name="sqlParameter">存储过程的参数</param>
    /// <returns>受影响行数</returns>
    public static int ExecuteNonQuery(ProcedureName procName, SqlParameter[] sqlParameter) 
    {
        try
        {
            using (SqlConnection conn=new SqlConnection(connStr))
            {
                conn.Open();
                SqlCommand cmd = new SqlCommand(procName.ToString(),conn);
                cmd.CommandType = CommandType.StoredProcedure;
                if (sqlParameter!=null)
                {
                    cmd.Parameters.AddRange(sqlParameter);
                }
                return cmd.ExecuteNonQuery();
            }
        }
        catch (Exception)
        {
            throw;
        }
    }

    /// <summary>
    /// 与数据库中显示存储过程交互的方法
    /// </summary>
    /// <param name="storedProcedure">存储过程名称</param>
    /// <param name="sqlParameter">存储过程的参数</param>
    /// <returns>受影响行数</returns>
    public static List<T> GetDataList<T>(ProcedureName procName, SqlParameter[] sqlParameter)
    {
        //处理异常机制
        try
        {
            //using自动释放资源
            using (SqlConnection conn = new SqlConnection(connStr))
            {
                //实例化执行命令对象,并在指定的数据库中执行指定的存储过程
                SqlCommand cmd = new SqlCommand(procName.ToString(), conn);
                //将执行命令对象的类型从文本类型转为存储过程
                cmd.CommandType = CommandType.StoredProcedure;
                //判断参数是否为空
                if (sqlParameter != null)
                {
                    //不为空,则添加到执行命令对象的参数列表中
                    cmd.Parameters.AddRange(sqlParameter);
                }
                //实例化适配器,匹配对应数据
                SqlDataAdapter sda = new SqlDataAdapter(cmd);
                //实例化一个数据表
                DataTable dt = new DataTable();
                //填充
                sda.Fill(dt);
                //调用转list方法,转化为list集合返回
                return DataToList<T>(dt);
            }
        }
        catch (Exception)
        {
            throw;
        }
    }


    /// <summary>
    /// dataTable数据表转为List泛型集合的反射方法
    /// </summary>
    /// <typeparam name="T">泛型</typeparam>
    /// <param name="dt">要转换的数据表</param>
    /// <returns>list泛型集合</returns>
    public static List<T> DataToList<T>(DataTable dt)
    {
        //实例化一个泛型集合
        List<T> list = new List<T>();
        //循环数据表中的行数据
        foreach (DataRow row in dt.Rows)
        {
            //实例化泛型T
            T t = System.Activator.CreateInstance<T>();
            //循环其属性
            foreach (PropertyInfo item in t.GetType().GetProperties())
            {
                //判断数据列名是否匹配属性名
                if (dt.Columns.Contains(item.Name))
                {
                    
                    //赋值到对应的属性
                    item.SetValue(t,row[item.Name],null);
                }
            }
            //将填充好数据的实体添加到集合中
            list.Add(t);
        }
        //返回集合
        return list;
    }

    /// <summary>
    /// 绑定下拉,与显示数据一样,只是,不用转list,直接返回dataTable
    /// </summary>
    /// <param name="procName">存储过程名称</param>
    /// <param name="sqlParameter">存储过程的参数</param>
    /// <returns></returns>
    public static DataTable BangDing(ProcedureName procName,SqlParameter[] sqlParameter)
    {
        try
        {
            using (SqlConnection conn=new SqlConnection(connStr))
            {
                SqlCommand cmd = new SqlCommand(procName.ToString(),conn);
                cmd.CommandType = CommandType.StoredProcedure;
                if (sqlParameter!=null)
                {
                    cmd.Parameters.AddRange(sqlParameter);
                }
                SqlDataAdapter sda = new SqlDataAdapter(cmd);
                DataTable dt = new DataTable();
                sda.Fill(dt);
                return dt;
            }
        }
        catch (Exception)
        {

            throw;
        }
    }


}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值