Limit fields in result of Propel v2 query with left join

593 Views Asked by At

I'm using Propel ORM v2 to retrieve records from a table which is linked to records of another table using foreign key. I'd like to return only certain fields from both the parent table and the child table.

What is the best way to do this?

My table structure looks like this:

Table: User
- Id
- Name
- Age
- MaritalStatus
Table: Profile
- UserId (FK->User.Id)
- Street
- City
- State
- Country
- TelephoneNumber

I have tried the following but the query does not return the desired User object with children Profile objects and only the selected fields of Id, Name for the User object and TelephoneNumber for the Profile child objects:

\UserQuery()::create
->select(array('Id', 'Name', 'Profile.Telephonenumber'))
->leftJoinWithProfile()
->find()
->toArray();

Any advise is greatly appreciated

2

There are 2 best solutions below

1
On

just took a quick look over Propel.

  1. This select returns what you have asked for, ('Id', 'Name', 'Profile.Telephonenumber').

    \UserQuery::create() ->join('Profile') ->select(array('Id', 'Name', 'Profile.Telephonenumber')) ->find() ->toArray();

    //returns an array with values for 'Id','Name', 'Profile.Telephonenumber'

  2. If you want all the entries of the 'User' table and entries from 'Profile' as a child array try this:

    \UserQuery::create() ->join('User.Profile') ->find() ->toArray();

    //returns an array with all the entries from 'User' table and an child array with entries from 'Profile' table.

Sorry if i made any mistakes, is my first answer on Stackoverflow.
Have a nice day,
M.I.

0
On

You should probably use withColumn(), e.g.

\UserQuery()::create()
    ->leftJoinWithProfile()
    ->withColumn('Profile.TelephoneNumber', 'TelephoneNumber')
    ->select(['Id', 'Name', 'TelephoneNumber'])
    ->find()
    ->toArray();