zoukankan      html  css  js  c++  java
  • Entity Framework小知识

    记录在使用EF中使用的技巧,以备查阅。

    1.当需要查询一个列总和的时候,如果列是允许NULL或者未查到信息的时候,想要返回的是0 而非NULL时

    db.表名.Sum(p=> (decimal?)p.Amount).GetValueOrDefault();
    

    2.记录一个最基础的左连接。。DefaultIfEmpty

    var restlt = from a in db.UserInfo
                  join b in db.UserMoreInfo on a.UserID equals b.UserID into ue
                  from c in ue.DefaultIfEmpty()
                  select c;

    3.将带有导航属性的对象存进Redis的时候报错。需要关闭延迟加载和动态创建。

    db.Configuration.LazyLoadingEnabled = false;
    db.Configuration.ProxyCreationEnabled = false;
    

    这是这两个属性的解释

    LazyLoadingEnabled 
    获取或设置一个值,该值指示是否启用针对公开为导航属性的关系的延迟加载。 延迟加载在默认情况下处于启用状态。 

    ProxyCreationEnabled 
    获取或设置一个值,该值指示框架在创建实体类型的实例时是否会创建动态生成的代理类的实例。 请注意,即使使用此标记启用了代理创建,也只会为满足代理设置要求的实体类型创建代理实例。 默认情况下启用代理创建。

    4.有时会有需要用SQL语句执行的,可以使用

    db.Database.SqlQuery<返回的实体类>(“SQL语句”).FirstOrDefault();
    db.Database.SqlQuery<返回的实体类>(“SQL语句”).OrderByDescending(x => x.newdate).Skip((CurrentPage-1)*pageSize).Take(pageSize).ToList();

    想起什么再补充补充。。

  • 相关阅读:
    ES6新特性
    ng-bind与ng-medol 区别
    验证输入两次密码是否一致angularjs
    最全的node.js安装步骤
    JAVA基础
    localStorage 个人使用总结
    mac中怎么安装python3
    macbook配置homebrew以及安装python3
    python之函数进阶
    mysql数据库入门
  • 原文地址:https://www.cnblogs.com/FangJiehua6/p/5990169.html
Copyright © 2011-2022 走看看