C#泛型反射把类转换成SQL

public void Add(T entity)
        {
            //保存字段名
            string st = string.Empty;
            //保存值
            string sv = string.Empty;
            //获取表名
            string Name = typeof(T).Name;

            //根据实例获取属性和值
            Type type = entity.GetType();
            List<SqlParameter> sqlParameters = new List<SqlParameter>();
            foreach (var item in type.GetProperties())
            {
                //检索指定类型用于特定成员的自定义属性
                KeyAttribute attr = item.GetCustomAttribute<KeyAttribute>();
                if (attr == null)
                {
                    //获取属性名,拼接字段
                    if (!string.IsNullOrEmpty(st))
                    {
                        st += ",";
                    }
                    st += item.Name;
                    if (!string.IsNullOrEmpty(sv))
                    {
                        sv += ",";
                    
                    }
                    sv += ("@" + item.Name);
                    sqlParameters.Add(new SqlParameter("@" + item.Name, item.GetValue(entity)));

                }
            }
            string sql = string.Format("insert into {0} ({1}) values({2})", Name, st, sv);
            


            
            
        }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值