刚小刚小刚 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 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置