首页 / C# / c#-Linq中子查询的有效方法
c#-Linq中子查询的有效方法
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c#-Linq中子查询的有效方法,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含940字,纯文字阅读大概需要2分钟。
内容图文
这是我的linq代码:
BOOK entity = db.BOOKS
.Where(s => s.ID == (from p in db.LIBRARY
from b in db.BOOKS
where (p.ID == 123) && (p.idpage == b.idpage)
select b.fields));
我实际的oracle代码是:
SELECT DISTINCT BOOKS.ID
FROM LIBRARY,BOOKS
WHERE LIBRARY.ID = 123 AND LIBRARY.ID = BOOKS.ID
但是它在s.ID中显示错误.
Delegate 'System.Func Project.Models.BOOKS,int,bool' does not take 1 arguments
为什么会这样?有什么解决方法吗?
解决方法:
您的SQL使用联接,因此您可以在LINQ中执行相同的操作.这些方法中的任何一种都足够:
// join
var query = (from b in db.BOOKS
join p in db.LIBRARY on b.IdPage equals p.IdPage
where p.ID == 123
select b.Id).Distinct();
// 2 from statements (SelectMany) can also be used as a join
var query = (from b in db.BOOKS
from p in db.LIBRARY
where p.ID == 123 && b.IdPage == p.IdPage
select b.Id).Distinct();
// fluent syntax
var query = db.BOOKS
.Where(b => db.LIBRARY.Any(p =>
p.ID == 123 && b.IdPage == p.IdPage))
.Select(b => b.Id)
.Distinct();
内容总结
以上是互联网集市为您收集整理的c#-Linq中子查询的有效方法全部内容,希望文章能够帮你解决c#-Linq中子查询的有效方法所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。