Reputation:
I read through lithium\data\model\query, but I didn't see any examples of joins.
Upvotes: 5
Views: 1608
Reputation: 4086
There are multiple ways to perform a join with Lithium.
join()
method (see the joins
.Connection->read()
.The other methods are reasonably well documented, so I'll give an example of passing Query objects to a finder.
$fields = array('id', 'name', 'slug');
$joins = array();
$joins[] = new Query(array(
'source' => 'client_tests',
'constraint' => array('Test.id' => 'client_tests.test_id'),
));
$conditions['client_id'] = $this->data['client_id'];
$tests = Test::all(array(
'conditions' => $conditions,
'fields' => $fields,
'joins' => $joins
));
The source
is the table that you want to join and constraint
is the join criteria. Lithium aliases the find table to the name of the model, so use that in your constraint. You can then pass the joins in to any finder along with any other parameters you want.
Note that at the time of writing, joins (and relationships) will only work with a relational database, not for things like MongoDB's DBRef.
Update: Removed links that have been link jacked.
Upvotes: 5
Reputation: 84348
If you set up a relationship (using hasOne, hasMany, or belongsTo) you can fetch the related data by supplying a with
key in the options of your find
call.
Like this:
$categories = Categories::find('all', array(
'with' => 'Products'
));
Check out the manual chapter on Relationships for more detail.
Upvotes: 1