转载 linq 实现查询字符串拼接 : And 和 OR 两种方式
转载 linq 实现查询字符串拼接 : And 和 OR 两种方式
N年前我们是这样来 拼接查询字符串的:
- public string Test(string a, string b, string c,string d)
- {
- string sql = "SELECT * FROM Users WHERE 1=1";
- if (!string.IsNullOrEmpty(a))
- {
- sql += " AND name='" + a + "'";
- }
- if (!string.IsNullOrEmpty(b))
- {
- sql += " AND age='" + b+ "'";
- }
- if (!string.IsNullOrEmpty(c))
- {
- sql += " AND sex='" + c + "'";
- }
- if (!string.IsNullOrEmpty(d))
- {
- sql += " AND address='" + d + "'";
- }
- return sql.ToString();
- }
现在我们使用linq来实现上边的代码:
[c-sharp]
- public void Test(string a, string b, string c,string d)
- {
- QueryContext query = new QueryContext();
- var q = from u in query.Users
- select u;
- if (!string.IsNullOrEmpty(a))
- {
- q = q.Where(p => p.name == a);
- }
- if (!string.IsNullOrEmpty(b))
- {
- q = q.Where(p => p.age == b);
- }
- if (!string.IsNullOrEmpty(c))
- {
- q = q.Where(p => p.sex == c);
- }
- if (!string.IsNullOrEmpty(d))
- {
- q = q.Where(p => p.address == d);
- }
- q.ToList(); //上边的所有if,只有到此处才会执行
- }
ps: 如果查询字符串内 不是AND,而是OR 的话
如:
- public string Test(string a, string b, string c,string d)
- {
- string sql = "SELECT * FROM Users WHERE 1=1";
- if (!string.IsNullOrEmpty(a))
- {
- sql += " OR name='" + a + "'";
- }
- if (!string.IsNullOrEmpty(b))
- {
- sql += " OR age='" + b+ "'";
- }
- if (!string.IsNullOrEmpty(c))
- {
- sql += " OR sex='" + c + "'";
- }
- if (!string.IsNullOrEmpty(d))
- {
- sql += " OR address='" + d + "'";
- }
- return sql.ToString();
- }
此种情况,通过linq可以这样实现:
[c-sharp]
- public void Test(string a,string b,string c,string d)
- {
- QueryContext query = new QueryContext();
- var q1 = from u in query.Users
- where u.name== a && a != ""
- || u.age == b && b != ""
- || u.sex == c && c != ""
- || u.address ==d && d !=""
- select u;
- q1.ToList();
- }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律