[odb-users] Query on many-to-one for "contains an object with property X"

Boris Kolpackov boris at codesynthesis.com
Wed Nov 8 11:28:10 EST 2017


Lukas Barth <lists at tinloaf.de> writes:

> #pragma db object
> class B
> {
>   int value;
> 
>   #pragma db not_null
>   shared_ptr<A> a;
>> };
> 
> #pragma db object
> class A
> {
> #pragma db inverse(a)
>  std::vector<std::shared_ptr<B>> bs;
>> };
> 
> I now want to query for all As that have a B with a value of 42 associated
> with them. I can't find the syntax for that (if that's possible) in the
> documentation. I would assume that I can access "bs" as as a field of A, but
> then I would need a "contains" operator and something to build the nested
> query, something along the lines of this:
> 
> db.query<A> (query::bs->contains( query<B>(query::value == 42) ))

Yes, using containers in query conditions is not yet supported (though
it's on a TODO list). The way you can achieve this now is with an object
loading view. I.e., join the two objects in a view, load A, and in
the query condition use B::value. Plus you will probably want the
distinct clause. The manual has more information and some examples.

Boris



More information about the odb-users mailing list