刚小刚小刚 2015-01-14 02:45 采纳率: 0%
浏览 1800

Linq to entities 多条件查询问题不知道有什么方法呢。

在用实体类建模时候,用Linq根据条件查询数据表,对于多个条件的查询,原来是需要什么条件就写一个方法,在开发途中发现条件确实是太多= =,

便想用几个公用方法来包含这些条件,也就是条件为空的时候不执行这个where罢了 比如:

        if (FromUserId != "" && ToUserId != "")
        {
            var query = from p in entities.T_Complaint
                        where
                        p.C_FromUserId.Equals(FromUserId)
                        && p.C_ToUserId.Equals(ToUserId)
                        select p;
        }.....

但是这两个条件就需要判断三次,这时候想用这个方法来解决

        var query = from p in entities.T_Complaint
                    where 
                    (FromUserId.Equals("")) ? true : p.C_FromUserId.Equals(FromUserId)
                    && (ToUserId.Equals("")) ? true : p.C_ToUserId.Equals(ToUserId)
                    select p;

可是Linq不支持条件啊,三元判断压根没用。不知道有什么方法呢。

  • 写回答

4条回答 默认 最新

  • threenewbee 2015-01-14 02:52
    关注
     var query =  entities.T_Complaint;
    if (FromUserId != "")
        query = query.Where(x => x.FromUserId == FromUserId);
    if (ToUserId !="")
       query = query.Where(x => x.ToUserId == ToUserId);
    
    评论

报告相同问题?

悬赏问题

  • ¥15 求差集那个函数有问题,有无佬可以解决
  • ¥15 MATLAB动图问题
  • ¥15 【提问】基于Invest的水源涵养
  • ¥20 微信网友居然可以通过vx号找到我绑的手机号
  • ¥15 寻一个支付宝扫码远程授权登录的软件助手app
  • ¥15 解riccati方程组
  • ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
  • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名