项目中的web api知识总结

Posted 随遇而安

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了项目中的web api知识总结相关的知识,希望对你有一定的参考价值。

         最近在做公司的项目,自己负责webapi的框架的搭建与开发,最近很忙,一直没时间对工作中遇到的知识点缺少个总结,现总结一下,对自己是个提升,如果个人的小点点小总结能对博友有帮助那也是善莫大焉.

(1)、 首先说一下c# dynamic,dynamic是FrameWork4.0的新特性.我在api中用了比较多的dynamic,首先个人认为dynamic能使代码变得优雅,可以省去定义多余的实体,dynamic是运行时决定类型有哪些属性,包括赋值和取值都可以随便指定属性,

例如:

dynamic sourceInfo = SqlDataHelper.GetWebDMDynamicData(sourceIdSql, new {id=3).FirstOrDefault();
                    if (null != sourceInfo)
                    {
                        item.SourceId = sourceInfo.SourceId;
                        item.DocType = sourceInfo.DocType;
                        item.InvestmentType = sourceInfo.InvestmentType;
                    }

以上代码中sourceInfo指定了dynamic,开发人员知道如果取值成功肯定会有SourceId属性,所以item.SourceId = sourceInfo.SourceId;赋值就不奇怪了.

同样如下代码也可以自己为dynamic随便指定属性:

1 dynamic data= null;
2 data= SqlDataHelper.GetWebDMDynamicData(sql, new { Id = id }).ToList().FirstOrDefault();
3 data.a= 124;
4 data.b= "test2";
5 data.c="test3";

可以为dynamic类型data随便指定属性,前提条件是在第(2)步骤时data的值不能为空,否则在第(3)步data是null,这时候就会出现空异常.

(2)、再谈论一下轻量级的ORM框架,这个框架网上已经充斥了大量的学习资料,本人只是对项目中的使用心得做些概括,不对之处欢迎指正.

        我们知道调用数据库存储过程肯定有参数化,dapper提供了一个比较好的参数化对象DynamicParameters,上代码:

DynamicParameters dynamicParameters = new DynamicParameters();
            dynamicParameters.Add("@p_Id1", id1, DbType.String);
            dynamicParameters.Add("@p_Id2", id2, DbType.Int32);
            dynamicParameters.Add("@p_dateTime", dateTime, DbType.DateTime);
            List<dynamic> info =  conn.Query<T>(storeProcedureName,dynamicParameters, null, true, null, CommandType.StoredProcedure) as List<T>;

        如果要指定执行存储过程,那么要指定CommandType.StoredProcedure关键字.

 (3)、以下是List<T>转dataTable的方法,的确为类型转换省去了好多的代码,但是也有一个自己花了点时间没有解决的问题,就是T必须指定实体类型,而不能使用dynamic,否则type.GetProperties

取不到正确的属性,这样系统就必须多定义一个实体类传进来.

 public static DataTable ToDataTable<T>(IList<T> list)
        {
            //create propertyInfo
            List<PropertyInfo> pList = new List<PropertyInfo>();
            //get reflector interface
            Type type = typeof(T);
            DataTable dt = new DataTable();
            //add datatable column
            Array.ForEach<PropertyInfo>(type.GetProperties(), p => { pList.Add(p); dt.Columns.Add(p.Name, Nullable.GetUnderlyingType(
            p.PropertyType) ?? p.PropertyType); });
            foreach (var item in list)
            {
                //create new row
                DataRow row = dt.NewRow();
                pList.ForEach(p => row[p.Name] = p.GetValue(item, null)??System.DBNull.Value);
                dt.Rows.Add(row);
            }
            return dt;
        }

好了,以上就是项目中的一些小小的总结,还有一些零碎的知识点不做过多描述了.通过项目过程中还有好多要学习的能力,特别是沟通能力,技术引导业务能力.

以上是关于项目中的web api知识总结的主要内容,如果未能解决你的问题,请参考以下文章

Vue3基础知识总结

Vue3基础知识总结

Vue3基础知识总结

前端知识体系-JS相关JS-Web-API总结

Java 容器在实际web项目中应用

线程学习知识点总结