zoukankan      html  css  js  c++  java
  • 解决Entity Framework查询匿名对象后的跨域访问的一种方式

    在Entity Framework中,可以使用lambda表达式进行对数据的查询,而且可以将查询结果直接映射为对象或者对象列表,这极大的提高的开发速度,并且使数据层的数据更加方便处理和传递。但是很多时候,我们不需要把整个表的字段都查出来,如果我们直接把整个数据实体查询出来,就极大的影响了性能,所以我们需要通过查询匿名对象或者已经定义的方式,对数据库进行查询;

    1.实例使用的数据实体类:

    public  class Category
    {
    public int Id { get; set; }
    public string Name { get; set; }
    public string Description { get; set; }
    }

    2.查询

    假设我们需要现实一个分类目录,我们只需要Id和Name两个字段,我们可以建立一个新的CategoryView

    public class CategoryView
    {
    public int Id { get; set; }
    public string Name { get; set; }
    }

    查询的时候,可以这样做,让它直接生成CategoryView的列表:

    var data1 = from c in context.Categoriees
    select new CategoryView()
    {
    Id = c.Id,
    Name = c.Name
    };

    这样,可以在将方法返回值设置为IQueryable<CategoryView>类型,在调用方法处可以直接遍历;

    然而,当没有CategoryView的时候,我们就只能使用匿名对象进行查询:

    var data = from c in context.Categoriees
    select new
    {
    cId = c.Id,
    cName = c.Name
    };

    这样的查询之后,同样可以直接通过cId和cName取值,但是仅限当前方法内部,如果跨域访问的话,就没法直接读出cId和cName的值了:

    CategoryService类的实现如下所示:

    namespace ConsoleApplication1
    {
    public class CategoryService
    {
    private ShopContext context=new ShopContext();

    public IQueryable<object> GetAllCategories()
    {
    var data = from c in context.Categoriees
    select new
    {
    cId = c.Id,
    cName = c.Name
    };
    return data;
    }
    }
    }

    调用方法:

    CategoryService service=new CategoryService();
    IQueryable<object> data = service.GetAllCategories();

    这时,我们是没法直接读取object类型的属性值的,在不考虑性能的前提下,我们可以使用反射,得到属性值:

    namespace ConsoleApplication1
    {
    class Program
    {
    static void Main(string[] args)
    {
    CategoryService service=new CategoryService();
    IQueryable<object> data = service.GetAllCategories();
    foreach (var item in data)
    {
    Type type = item.GetType();
    PropertyInfo idProperty = type.GetProperty("cId");
    string id = idProperty.GetValue(item, null).ToString();
    PropertyInfo nameProperty = type.GetProperty("cName");
    string name = nameProperty.GetValue(item, null).ToString();

    Console.WriteLine("Id:"+id+" Name:"+name);
    }
    Console.ReadKey();
    }
    }
    }

    当然,这样的操作,如果您觉得性能的问题不比需要建立CategoryView模型类造成的麻烦多的话,还是一种比较简单快捷的实现方式,但是我的建议还是建立像CategoryView这样的视图模型类,可以发这个类对象传递给视图直接显示,何乐不为!!!

    3.目前为止我所知的最好的跨域访问方式

    在c#4.0中,加入了dynamic特性,这使得我们可以使用它支持对动态类型的解释,虽然c#语言绝对是静态类型的,但是dynamic通过在编译的时候,不推断出具体类型,而是展开为表达式数的形式,在最后执行期间使用代理去执行调用的方法,是对匿名类型的调用比使用反射机制更加高效便捷了,所以,对于上述实例,可以使用如下方式进行调用:

    foreach (dynamic item in data)
    {
    Console.WriteLine(item.cId);
    }

    而我们失去的,只是visual studio的智能提示而已,所以目前看来,这是最适当的一种方法,当然,如果是和UI层链接的服务层,我仍然推荐使用查询ViewModel的方式

  • 相关阅读:
    CodeForces 626 DIV.2 D Present
    PageRank 算法初步了解
    LeetCode 329. Longest Increasing Path in a Matrix(DFS,记忆化搜索)
    LeetCode 312. Burst Balloons(DP)
    LeetCode Contest 180
    用js来实现那些数据结构12(散列表)
    用js来实现那些数据结构11(字典)
    用js来实现那些数据结构10(集合02-集合的操作)
    用js来实现那些数据结构09(集合01-集合的实现)
    用js来实现那些数据结构08(链表02-双向链表)
  • 原文地址:https://www.cnblogs.com/xiaoyaojian/p/3671259.html
Copyright © 2011-2022 走看看