Linq 条件查询的一些方法

1.LINQ的IN:
var queryResult = from p in db.Products
where (new int?[] {1,2}).Contains(p.CategoryID)
select p;

2.LINQ的NOT IN:
var queryResult = from p in db.Products
where !(new int?[] { 1, 2 }).Contains(p.CategoryID)
select p;

3.LINQ的NOT IN 遍历集合

List<string> source = new List<string>{ "aaa", "bbb" };        

List<string> px = new  List<string> { "aaa", "bbb", "ccc" }; 

 var q = from s in source   

        from p in px                  

         where s==p        

          select s;

4.SQL中的in和not in语法对应的LINQ写法

    List<testInfo> listAll = new List<testInfo>();  
    listAll.Add(new testInfo() { id = 1, name = "11", test = "111" });  
    listAll.Add(new testInfo() { id = 2, name = "22", test = "222" });  
    listAll.Add(new testInfo() { id = 3, name = "33", test = "333" });  
    listAll.Add(new testInfo() { id = 4, name = "33", test = "333" });  
      
    List<testInfo> listFind = new List<testInfo>();  
    listFind.Add(new testInfo() { id = 1, name = "44", test = "111" });  
    listFind.Add(new testInfo() { id = 2, name = "22", test = "222" });  
    listFind.Add(new testInfo() { id = 3, name = "33", test = "333" });  
    listFind.Add(new testInfo() { id = 4, name = "55", test = "333" });  
    //SQL中的in和not in语法对应的LINQ写法  
   //相当于查询语句:select * from listAll p where p.name not in(select f.name from listFind)  
    var a = (from p in listAll  
             where !(from f in listFind select f.name).Contains(p.name)  
             select p).ToList();  

 

转载于:https://www.cnblogs.com/liuyu7177/archive/2013/05/29/3105688.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值