日期:2014-05-17  浏览次数:20572 次

求教个关于Sql to Linq 的问题
如图:

我要先判断name,startime,endtime不为空,然后在写后面的条件,但是这样写,代码好像太那个了,有没有什么好点的写法,比如Sql里那种拼Where 条件一样,写出来很简洁的
------解决方案--------------------
refer my blog: 
http://blog.csdn.net/q107770540/article/details/5724013#comments


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

 

 

[c-sharp] view plaincopy
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] view plaincopy
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