Fluent Mybatis 关联查询中关于OR条件的使用

文章介绍了在处理数据库查询时遇到的关联查询场景,特别是涉及AND条件(A.xxorA.ccorB.xx)的情况。通过示例展示了如何使用ORM框架,如创建新的AQuery和BQuery对象,设置选择列和过滤条件,并进行LEFTJOIN操作来构建复杂的查询。最终,通过mapper接口执行查询并获取结果列表。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

遇到关联查询,然后需要使用and(A.xx or A.cc or B.xx)场景, 在Query 不相同下可以使用如下解决办法,注意new AQuery(“D”) 与 Query aQuery = new AQuery(“D”) 要一致。

		Query aQuery = new AQuery("D")
                .select
                .realname("doctorName")
                .end();
                
        BQuery bQuery = new BQuery("P")
                .select
                .name("patientName")
                .end()
                .where
                .and(q -> q.where.name().like(so.getTerm(), If::notBlank)
                        .or.idcard().like(so.getTerm(), If::notBlank)
                        .or.phone().like(so.getTerm(), If::notBlank)
                        .or(new AQuery("D").select
                        .realname("doctorName")
                        .end()
                        .where
                        .realname().like(so.getTerm(), If::notBlank)
                        .end())
                        .end())
                .end();
        MQuery mQuery = mapper.query()
                .selectAll()
                .where
                .id().ne("null")
                .end()
        IQuery query = JoinBuilder
                .from(mQuery )
                .leftJoin(aQuery )
                .on(l -> l.where.doctorId(), r -> r.where.id())
                .endJoin()
                .leftJoin(bQuery )
                .on(l -> l.where.patientId(), r -> r.where.id())
                .endJoin()
                .build();
        return mapper.listEntity(query);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值