linq to ef(相当于sql中in的用法)查询语句

select * from DoctorInfo doctor
where doctor.HosDepartId in
(select Id from HospitalDepartment hd
where hd.DepartmentId=5)


var a=from d in _entity.HospitalDepartment
where d.DepartmentId==5
select d;

List<int> lst=new List<int>();
foreach(var b in a)
{
lst.add(b);
}

var doc=from c in _entity.DoctorInfo
where lst.contains(c.HospitalId)
select c;

转载于:https://www.cnblogs.com/love828/p/3918031.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1.了解查询语法和方法语法 LINQ提供两种语法:查询语法和方法语法。查询语法使用类似SQL的语法来编写查询,而方法语法使用类似于扩展方法的语法。熟悉这两种语法可以帮助您更好地编写LINQ查询。 2.使用延迟加载 延迟加载可以提高应用程序的性能。延迟加载是指在需要使用数据时才从数据库检索数据。这意味着只有在需要时才会打开数据库连接和执行查询,从而减少了数据库的负载。 3.使用Lambda表达式 Lambda表达式是一种匿名函数,它可以使代码更加简洁和易于阅读。在LINQ,Lambda表达式通常用于筛选和排序数据。 4.使用投影 投影是指从查询结果选择特定的字段或属性。使用投影可以减少返回的数据量,从而提高查询性能。 5.避免N+1查询问题 N+1查询问题是指在查询使用了循环,并且在循环每次都执行了一个额外的查询。这会导致性能问题。可以使用Eager Loading或包含查询来解决N+1查询问题。 6.使用事务 在修改数据时,使用事务可以确保数据的一致性。如果在事务提交之前发生了错误,事务会自动回滚。在LINQ,可以使用TransactionScope类来管理事务。 7.选择正确的集合类型 在LINQ,有多种集合类型可供选择,包括List、HashSet、Dictionary等。选择正确的集合类型可以提高查询性能和代码可读性。 8.使用索引 使用索引可以加快查询速度。在LINQ,可以使用索引来加快查询速度,例如使用First、Single、FirstOrDefault等方法来获取特定的元素。 9.使用AsNoTracking AsNoTracking是一种方法,它可以告诉LINQ不要跟踪对象的更改状态。使用AsNoTracking可以提高查询性能,尤其是在查询大量数据时。 10.注意内存泄漏 在使用LINQ时,需要注意内存泄漏问题。LINQ查询会创建大量的临时对象,如果这些对象没有被正确释放,就会导致内存泄漏。可以使用using语句或手动释放对象来避免内存泄漏。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值