转载 linq 实现查询字符串拼接 : And 和 OR 两种方式

转载 linq 实现查询字符串拼接 : And 和 OR 两种方式

N年前我们是这样来 拼接查询字符串的:

 

[c-sharp]
  1. public string Test(string a, string b, string c,string d)  
  2.    {  
  3.        string sql = "SELECT * FROM Users WHERE 1=1";  
  4.        if (!string.IsNullOrEmpty(a))  
  5.        {  
  6.            sql += " AND name='" + a + "'";  
  7.        }  
  8.        if (!string.IsNullOrEmpty(b))  
  9.        {  
  10.            sql += " AND age='" + b+ "'";  
  11.        }  
  12.        if (!string.IsNullOrEmpty(c))  
  13.        {  
  14.            sql += " AND sex='" + c + "'";  
  15.        }  
  16.        if (!string.IsNullOrEmpty(d))  
  17.        {  
  18.            sql += " AND address='" + d + "'";  
  19.        }  
  20.        return sql.ToString();  
  21.    }  

 

现在我们使用linq来实现上边的代码:

 [c-sharp]

  1. public void Test(string a, string b, string c,string d)  
  2.        {  
  3.            QueryContext query = new QueryContext();  
  4.            var q = from u in query.Users  
  5.                     select u;  
  6.            if (!string.IsNullOrEmpty(a))  
  7.            {  
  8.                q = q.Where(p => p.name == a);  
  9.            }  
  10.            if (!string.IsNullOrEmpty(b))  
  11.            {  
  12.                q = q.Where(p => p.age == b);  
  13.            }  
  14.            if (!string.IsNullOrEmpty(c))  
  15.            {  
  16.                q = q.Where(p => p.sex == c);  
  17.            }  
  18.            if (!string.IsNullOrEmpty(d))  
  19.            {  
  20.                q = q.Where(p => p.address == d);  
  21.            }  
  22.            q.ToList();  //上边的所有if,只有到此处才会执行  
  23.        }  

 

ps: 如果查询字符串内 不是AND,而是OR 的话

如:

 

 

[c-sharp]
  1. public string Test(string a, string b, string c,string d)  
  2.    {  
  3.        string sql = "SELECT * FROM Users WHERE 1=1";  
  4.        if (!string.IsNullOrEmpty(a))  
  5.        {  
  6.            sql += " OR name='" + a + "'";  
  7.        }  
  8.        if (!string.IsNullOrEmpty(b))  
  9.        {  
  10.            sql += " OR age='" + b+ "'";  
  11.        }  
  12.        if (!string.IsNullOrEmpty(c))  
  13.        {  
  14.            sql += " OR sex='" + c + "'";  
  15.        }  
  16.        if (!string.IsNullOrEmpty(d))  
  17.        {  
  18.            sql += " OR address='" + d + "'";  
  19.        }  
  20.        return sql.ToString();  
  21.    }  

此种情况,通过linq可以这样实现:

 

[c-sharp]

  1. public void Test(string a,string b,string c,string d)  
  2.     {  
  3.              QueryContext query = new QueryContext();  
  4.              var q1 = from u in query.Users  
  5.                       where u.name== a && a != ""  
  6.                   || u.age == b && b != ""  
  7.                   || u.sex == c && c != ""  
  8.                   || u.address ==d && d !=""   
  9.                       select u;  
  10.              q1.ToList();  
  11.     }  

posted on   新西兰程序员  阅读(165)  评论(0编辑  收藏  举报

(评论功能已被禁用)
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

点击右上角即可分享
微信分享提示