Join map and refer to its key/value in HQL

Posted by alamar on Stack Overflow See other posts from Stack Overflow or by alamar
Published on 2010-06-11T06:23:16Z Indexed on 2010/06/11 6:43 UTC
Read the original article Hit count: 486

Filed under:
|
|

Suppose I have a map:

    <map name="externalIds" table="album_external_ids">
        <key column="album_id" not-null="true"/>
        <map-key-many-to-many class="Major" column="major_id"/>
        <element column="external_id" type="string" not-null="true"/>
    </map> 

How do I make a HQL meaning "select entities where map key's id == :foo and map value == :bar"?

I can join it using select album from Album album join album.externalIds ids But how would I then refer to ids' key and value? ids.key.id = :foo and ids.value = :bar doesn't work, and hibernate doc is silent on this topic.

Naive approaches that didn't work:

select album from Album album join album.externalIds externalId where index(externalId).id = :foo and externalId = :bar

and

select album from Album album join album.externalIds externalId join index(externalId) major where major.id = :foo and externalId = :bar

© Stack Overflow or respective owner

Related posts about hibernate

Related posts about map