C# 拼接实体类属性名称用于SQL语句中

1、在使用ORM框架时候,往往都会遇到一个较为繁琐的事情就是字符串的拼接问题,一般情况下查询SQL Server数据库SQL语句主要包含一下三种类型。

public const string entity = "code,pcode,_name,serve_id,ip_address,dead_drive,";
public const string atentity = "@code,@pcode,@_name,@serve_id,@ip_address,@dead_drive,";
public const string upentity = "code=@code,pcode=@pcode,_name=@_name,serve_id=@serve_id,ip_address=@ip_address,dead_drive=@dead_drive,";

2、前提创建好了实体类,调用以下方法拼接字符。

 public class splicing<T> where T:class
    {
        public string propertyName() {
            System.Reflection.PropertyInfo[] pi = typeof(T).GetProperties();
            if (pi == null) { return null; }
            string reStr = "";
            foreach (var item in pi)
            {
                reStr += item.Name + ",";
            }
            return reStr;
        }

        public string propertyAtName() {
            System.Reflection.PropertyInfo[] pi = typeof(T).GetProperties();
            if (pi == null) { return null; }
            string reStr = "";
            foreach (var item in pi)
            {
                reStr += "@" + item.Name + ",";
            }
            return reStr;

        }
        public string propertyEqualsName()
        {
            System.Reflection.PropertyInfo[] pi = typeof(T).GetProperties();
            if (pi == null) { return null; }
            string reStr = "";
            foreach (var item in pi)
            {
                reStr += item.Name + "=@" + item.Name + ",";
            }
            return reStr;

        }
    }
public class sd_test_item
    {
        /// <summary>
        /// 大项目名称
        /// </summary>
        public string big_name { get; set; }
        /// <summary>
        /// 子项目标识
        /// </summary>
        public string item_id { get; set; }
        /// <summary>
        /// 描述
        /// </summary>
        public string describe { get; set; }
        /// <summary>
        /// 测试模式
        /// </summary>
        public string test_model { get; set; }
        /// <summary>
        /// 结果数据点
        /// </summary>
        public string result_data { get; set; }
        /// <summary>
        /// 设定值数据点
        /// </summary>
        public string set_point { get; set; }
        /// <summary>
        /// 上限数据点
        /// </summary>
        public string upper_limit { get; set; }
        /// <summary>
        /// 下限数据点
        /// </summary>
        public string lower_limit { get; set; }
        /// <summary>
        /// 测试值数据点
        /// </summary>
        public string test_value { get; set; }
    }
static void Main(string[] args)
{
   splicing<sd_test_item> SBI = new splicing<sd_test_item>();
   Console.WriteLine(SBI.propertyName());
   Console.WriteLine(SBI.propertyAtName());
   Console.WriteLine(SBI.propertyEqualsName());
   Console.Read();
}

 

 

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值