通过反射+泛型操作 sql的CRUD语句

这篇博客介绍如何利用反射和泛型在C#中动态地执行SQL的CRUD操作,通过示例展示了如何根据不同的条件创建查询方法,从而实现对数据库的灵活操作。
摘要由CSDN通过智能技术生成

此中有多个不同条件的同功能方法
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Threading.Tasks;

namespace APIDal
{
//dal
public class DBHelper where T : class, new()
{
/在此处可以直接写数据库的连接语句/
//获取连接字符串
private static string con = System.Configuration.ConfigurationManager.ConnectionStrings[“conStr”].ConnectionString;
#region 动态查询的方式使用泛型+反射
//sql语句 select *from student
public static List Query(string where)
{
DataTable tb = new DataTable();
List list = new List();

        //
        string sql = GetQuerySql();
        sql += where;
        //用反射赋值
        using (SqlConnection connection = new SqlConnection(con))
        {
            connection.Open();
            using (SqlCommand command = new SqlCommand(sql, connection))
            {
                SqlDataAdapter sqlDataAdapter = new SqlDataAdapter(command);
                sqlDataAdapter.Fill(tb);
                //获取T的类型
                Type type = typeof(T);
                //循环循环行
                for (int i = 0; i < tb.Rows.Count; i++)
                {
                    //实例化T,每一次都需要实例化new 对象
                    Object obj = Activator.CreateInstance(type);
                    //循环列
                    for (int j = 0; j < tb.Columns.Count; j++)
                    {
                        //获取列的名称 student s_id  GetProperty("s_id")
                        PropertyInfo info = type.GetProperty(tb.Columns[j].ColumnName);//赋值了s_id

                        //判断类型 tb.Columns[j].DataType 获取数据库列的类型

                        #region 类型的判断并赋值
                        //int类型


                        if (tb.Columns[j].DataType == typeof(Int32))
                        {
                            //有没有可能空值?
                            if (tb.Rows[i][j] != null)
                            {
                                //obj.setValue(info,12);
                                info.SetValue(obj, int.Parse(tb.Rows[i][j].ToString()), null);
                            }
                            else
                            {
                                //null值的情况
                                info.SetValue(obj, 0, null);
                            }
                        }

                        //float类型
                        else if (tb.Columns[j].DataType == typeof(float))
                        {
                            //有没有可能空值?
                            if (tb.Rows[i][j] != null)
                            {
                                info.SetValue(obj, float.Parse(tb.Rows[i][j].ToString()), null);
                            }
                            else
                            {
                                //null值的情况
                                info.SetValue(obj, 0.0f, null);
                            }
                        }

                        //datetime
                        else if (tb.Columns[j].DataType == typeof(DateTime))
                        {
                            //有没有可能空值?
                            i
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值