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();

想起什么再补充补充。。

 

转载于:https://www.cnblogs.com/FangJiehua6/p/5990169.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值