排名
1
文章
860
粉丝
112
评论
163
.net core自定义项目模板,创建自己的模板项目,使用命令行创建模板项目
尘叶心繁 : 可以可以讲真的我都想弄个模板
net core webapi post传递参数
庸人 :
确实坑哈,我也是下班好了好几次,发现后台传递对象是可以的,但...
.net webapi 返回需要的字段,忽略某些字段,修改字段名等
雨雨雨雨雨辰 : 已精
.net webapi 返回需要的字段,忽略某些字段,修改字段名等
雨雨雨雨雨辰 :
疯狂反射
百度编辑器自定义模板
庸人 : 我建议换个编辑器,因为现在百度富文本已经停止维护了,用tinymec...
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:
50010702506256


欢迎加群交流技术
原
Entity Framework常用查询,EF join,EF多表联查,原生sql。EF 多表查询。AsNoTracking

直接执行sql语句
- //全表查询
- List<Users> ulist = se.Database.SqlQuery<Users>("select * from users").ToList();
接条件很也方便
- //接条件查询
- List<Users> ulist = se.Database.SqlQuery<Users>("select * from users where number=@number", new SqlParameter("number", "NS001")).ToList();
执行添加,删除,修改等操作
- int count =Database.ExecuteSqlRaw(sql,params);
执行添加,删除,修改等操作 方法2:
- context.Database.ExecuteSqlInterpolated()
直接执行存储过程语句
- //执行存储过程并取得返回值
- int prlr = myc.Database.SqlQuery<int>("exec [ProSelectCount] '1'").SingleOrDefault();
AsNoTracking()不跟踪上下文可以提高查询效率
- context.Article.AsNoTracking()
Ef 两表Join
linq写法:
- //两表join linq写法
- var query = from u in oae.Users
- join p in oae.Parent on u.Id equals p.ParentId
- select new
- {
- username = u.UserName,
- father = p.Father
- };
lamdba写法:
- /*
- 第一个参数: join的表
- 第二,三参数: 连接条件
- 第四个参数: 返回值
- */
- var query = oae.Users.Join(oae.Parent, a => a.Id, b => b.ParentId, (a, b) => new
- {
- username = a.UserName,
- fahter = b.Father
- });
Ef 两表 left Join
linq写法:
- //两表left join linq写法
- var query = from u in oae.Users
- join p in oae.Parent on u.Id equals p.ParentId into jtemp
- from leftjoin in jtemp.DefaultIfEmpty()
- select new
- {
- username = u.UserName,
- father = leftjoin.Father
- };
lamdba写法:
- //两表left join lamdba写法
- var query = oae.Users.GroupJoin(oae.Parent, a => a.Id, b => b.ParentId, (a, b) => new
- {
- username = a.UserName,
- parent = b
- }).SelectMany(a => a.parent, (m, n) => new
- {
- username = m.username,
- father = n.Father
- });
lamdba的写法主要用到了groupjoin与SelectMany,这里简单解释一下:
groupjoin: 用于查询一对多的关系很方便,所以得数据格式就是1对多的关系
SelectMany: 可以解析集合中含有集合的情况(也就是1对多的表现)为单一对象
Ef三表Join
linq写法:
- //三表join linq写法
- var queru = from u in oae.Users
- join p in oae.Parent on u.Id equals p.ParentId
- join s in oae.Score on u.Id equals s.UsersId
- select new
- {
- username = u.UserName,
- fahter = p.Father,
- sub = s.Sub,
- score = s.Score1
- };
lamdba写法:
- //三表join lamdba写法
- var query = oae.Users.Join(oae.Parent, a => a.Id, b => b.ParentId, (a, b) => new
- {
- uid = a.Id,
- username = a.UserName,
- father = b.Father
- }).Join(oae.Score, a => a.uid, b => b.UsersId, (m, n) => new
- {
- username = m.username,
- father = m.father,
- sub = n.Sub,
- score = n.Score1
- });
其实和两表join类似,往后面点就行了
Ef三表left Join
Linq写法:
- //三表left join linq写法
- var query = from u in oae.Users
- join p in oae.Parent on u.Id equals p.ParentId into ptemp
- join s in oae.Score on u.Id equals s.UsersId into stemp
- from leftp in ptemp.DefaultIfEmpty()
- from lefts in stemp.DefaultIfEmpty()
- select new
- {
- username = u.UserName,
- father = leftp.Father,
- sub = lefts.Sub,
- score = lefts.Score1
- };
lamdba写法:
- //三表left join lamdba写法
- var query = oae.Users.GroupJoin(oae.Parent, a => a.Id, b => b.ParentId, (a, b) => new
- {
- uid = a.Id,
- username = a.UserName,
- parent = b
- }).GroupJoin(oae.Score, a => a.uid, b => b.UsersId, (m, n) => new
- {
- username = m.username,
- uid = m.uid,
- score = n,
- parent = m.parent
- }).SelectMany(a => a.parent.DefaultIfEmpty(), (m, n) => new
- {
- username = m.username,
- fahter = n.Father,
- score = m.score
- }).SelectMany(a => a.score.DefaultIfEmpty(), (m, n) => new
- {
- usernaem = m.username,
- father = m.fahter,
- sub = n.Sub,
- score = n.Score1
- });
lamdba写法2:上面是现join完在selectmany,也可以先selectmany了在join第三张表
- //三表left join lamdba写法2
- var query = oae.Users.GroupJoin(oae.Parent, a => a.Id, b => b.ParentId, (a, b) => new
- {
- uid = a.Id,
- username = a.UserName,
- parent = b
- }).SelectMany(a => a.parent.DefaultIfEmpty(), (m, n) => new
- {
- uid = m.uid,
- username = m.username,
- father = n.Father
- }).GroupJoin(oae.Score, a => a.uid, b => b.UsersId, (m, n) => new
- {
- username = m.username,
- father = m.father,
- score = n
- }).SelectMany(a => a.score, (m, n) => new
- {
- username = m.username,
- father = m.father,
- sub = n.Sub,
- score = n.Score1
- });
单表分组函数
linq:
- //linq
- var query = from score in oae.Score
- group score by score.Sub into grouptemp
- select new
- {
- sub = grouptemp.Key,
- sum = grouptemp.Sum(a => a.Score1),
- max = grouptemp.Max(a => a.Score1),
- min = grouptemp.Min(a => a.Score1),
- avg = grouptemp.Average(a => a.Score1)
- };
lamdba:
- //lamdba
- var query = oae.Score.GroupBy(a => a.Sub).Select(grouptemp => new
- {
- sub = grouptemp.Key,
- sum = grouptemp.Sum(a => a.Score1),
- max = grouptemp.Max(a => a.Score1),
- min = grouptemp.Min(a => a.Score1),
- avg = grouptemp.Average(a => a.Score1)
- }).Where(a => a.max > 60);
-
- var result = query.ToList();
分组函数后接一点条件
linq:
- //linq
- var query = from score in oae.Score
- group score by score.Sub into grouptemp
- where grouptemp.Sum(a=>a.Score1)>60
- select new
- {
- sub = grouptemp.Key,
- sum = grouptemp.Sum(a => a.Score1),
- max = grouptemp.Max(a => a.Score1),
- min = grouptemp.Min(a => a.Score1),
- avg = grouptemp.Average(a => a.Score1)
- };
linq写法2:
- //linq
- var query = from score in oae.Score
- group score by score.Sub into grouptemp
- select new
- {
- sub = grouptemp.Key,
- sum = grouptemp.Sum(a => a.Score1),
- max = grouptemp.Max(a => a.Score1),
- min = grouptemp.Min(a => a.Score1),
- avg = grouptemp.Average(a => a.Score1)
- } into temp
- where temp.max > 60
- select new
- {
- sub = temp.sub,
- sum = temp.sum
- };
- var result = query.ToList();
两表分组函数
对某个考生的成绩统计
linq形式:
- var query = from u in oae.Users
- join s in oae.Score on u.Id equals s.UsersId
- select new
- {
- UserName = u.UserName,
- Score1 = s.Score1
- } into jointemp
- group jointemp by jointemp.UserName into a
- select new ScoreViewModel
- {
- UserName = a.Key,
- Count = a.Count(),
- Max = a.Max(b => b.Score1),
- Min = a.Min(b => b.Score1),
- Sum = a.Sum(b => b.Score1),
- Avg = a.Average(b => b.Score1)
- };
- List<ScoreViewModel> result = query.ToList();
三表分组函数
对某个考生的成绩统计,并包含考生父母
linq形式:
- var query = from u in oae.Users
- join p in oae.User_Parent on u.Id equals p.UsersId into upjointemp
- from leftjoin in upjointemp.DefaultIfEmpty()
- join s in oae.Score on u.Id equals s.UsersId
- select new
- {
- UserName = u.UserName,
- Father = leftjoin.Father,
- Score1 = s.Score1
- } into jointemp
- group jointemp by new { jointemp.UserName, jointemp.Father } into a
- select new ScoreViewModel
- {
- UserName = a.Key.UserName,
- Father = a.Key.Father ?? "孤儿",
- Count = a.Count(),
- Max = a.Max(b => b.Score1),
- Min = a.Min(b => b.Score1),
- Sum = a.Sum(b => b.Score1),
- Avg = a.Average(b => b.Score1)
- };
- List<ScoreViewModel> result = query.ToList();
未完待续........
欢迎加群讨论技术,1群:677373950(满了,可以加,但通过不了),2群:656732739。有需要软件开发,或者学习软件技术的朋友可以和我联系~(Q:815170684)
评价
Murphy
看到这个又想起当初学的时候的感觉![[嘻嘻]](http://www.tnblog.net/content/static/layui/images/face/1.gif)