zoukankan      html  css  js  c++  java
  • 将实体类/匿名对象转换为SqlParameter列表

     每次操作数据库参数化实在是太麻烦了,于是自己瞎琢磨,琢磨出下面扩展方式,能力有限,还有不足之处,请多多指教。

    /// <summary>
    /// <remarks>
    /// <para>将实体类/匿名对象转换为SqlParameter列表</para>
    /// <para>示例1: 实体类</para>
    /// <para>EntityClass entityClass = new EntityClass(){ Id = 1 , Name="名称"}; SqlParameter[] parms = entityClass.ToSqlParameterArray()</para>
    /// <para>示例2: 匿名对象</para>
    /// <para>var anonymousObject  = new { Id = 1 , Name="名称"}; SqlParameter[] parms = anonymousObject.ToSqlParameterArray()</para>
    /// <para>注意:SqlParameter(string parameterName, object value)的参数parameterName均为实体类/匿名对象属性的小写形式的副本。</para>
    /// <para>因此,对应sql参数应为小写形式,例如:insert into tbname(name) values(@name)</para>
    /// </remarks>
    /// </summary>
    /// <param name="obj">实体类/匿名对象</param>
    /// <returns>SqlParameter参数数组</returns>
    public static SqlParameter[] ToSqlParameterArray<T>(this T entityClass) where T : class
    {
        List<SqlParameter> parms = new List<SqlParameter>();
        PropertyInfo[] propertys = entityClass.GetType().GetProperties();
        foreach (PropertyInfo pi in propertys)
        {
            // 判断此属性是否有Getter
            if (!pi.CanRead)
            {
                continue;
            }
            object value = pi.GetValue(entityClass);
            parms.Add(new SqlParameter("@" + pi.Name.ToLower(), value));
        }
        return parms.ToArray();
    }
    

     使用示例:

    1.实体类

    public class EntityClass
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public int Age { get; set; }
    }
    
    EntityClass ec = new EntityClass()
    {
        Name= "长毛象",
        Age = 2
    };
    //SqlParameter[] parms = ec.ToSqlParameterArray();
    var parms = ec.ToSqlParameterArray();
    

    2.匿名类

    var ec = new
    {
        Name = "长毛象",
        Age = "2"
    };
    //SqlParameter[] parms = ec.ToSqlParameterArray();
    var parms = ec.ToSqlParameterArray();
    
  • 相关阅读:
    第02组 Beta版本演示
    2020系统综合实践8 大作业 智能门禁
    2020系统综合实践6 树莓派基本入门
    2020系统综合实践5 使用Dokcer部署Python运行环境
    2020系统综合实践4 Dokcer专题实践
    2020系统综合实践3 使用Docker Compose部署LNMP
    2020系统综合实践2 使用Dokcer部署Nginx和MySQL容器
    2020系统综合实践1 WSL 2的安装和基本使用
    2020系统综合实践1 VirtualBox下安装Debian踩坑小结
    团队第六次——beta冲刺日志集合
  • 原文地址:https://www.cnblogs.com/xiangyisheng/p/7640573.html
Copyright © 2011-2022 走看看