Добавить = значение в левом предложении соединения, используя запрос на выполнение - PullRequest
0 голосов
/ 30 октября 2018

Работа с Grails 3.3.8 и Mysql DB 5.5.x версии. Я сделал этот запрос:

 String query = $/
            select new Map( i1.id as id,i1.name as name)
            from CustomerComposition as c1
            inner join c1.instrument as i1
            left join i1.analisys as a1,
            Instrument as i2
            left join i2.analisys as a2,
            Instrument as i3
            left join i3.analisys as a3
            where 
            i1.id=i2.id and i1.id=i3.id and
            c1.portfolio.id=:ptfId and a1.phase.id=:p1Id and a2.phase.id=:p2Id and a3.phase.id=:p3Id 
        /$

        List composition = CustomerComposition.executeQuery(query,
                [ptfId: ptfId, p1Id: phase[0], p2Id: phase[1], p3Id: phase[2]])

Левое соединение не работает. Тогда я понимаю, что это не работает, потому что я помещаю предложение в ГДЕ. Я дважды проверяю простую SQL-статистику, и она действительно работает, когда условное выражение перемещено куда-то. Простой отрывок, взятый только для пояснения, раньше и не сработал:

SELECT
instrument1_.id
FROM
    customer_ptf_composition customerpt0_
    INNER JOIN instrument instrument1_ ON customerpt0_.instrument_id = instrument1_.id
    LEFT JOIN analisys analisys4_ ON instrument1_.id = analisys4_.instrument_id

WHERE
customerpt0_.portfolio_id =1216 
    AND analisys4_.phase_id =111

и после, и это работает из-за того, как работает соединение влево / вправо:

SELECT
instrument1_.id
FROM
    customer_ptf_composition customerpt0_
    INNER JOIN instrument instrument1_ ON customerpt0_.instrument_id = instrument1_.id
    LEFT JOIN analisys analisys4_ ON instrument1_.id = analisys4_.instrument_id AND analisys4_.phase_id =111 

WHERE
customerpt0_.portfolio_id =1216

Теперь мой вопрос: как я могу поместить "and field = value" рядом с левым соединением в GORM?

1 Ответ

0 голосов
/ 30 октября 2018

Вы можете использовать предложение WITH для достижения этого:

left join i3.analisys a3 WITH a3.something = :someValue

См. Также: текущее руководство пользователя Hibernate: явное соединение HQL

...