From 1de19626dfec6a34c534ceb7a1f3ad810248ea79 Mon Sep 17 00:00:00 2001 From: zYne Date: Mon, 6 Aug 2007 19:37:01 +0000 Subject: [PATCH] --- manual/new/docs/en/working-with-objects.txt | 43 +++++++++++++++++++++ 1 file changed, 43 insertions(+) diff --git a/manual/new/docs/en/working-with-objects.txt b/manual/new/docs/en/working-with-objects.txt index 5b2b88ec5..00e8e8221 100644 --- a/manual/new/docs/en/working-with-objects.txt +++ b/manual/new/docs/en/working-with-objects.txt @@ -1,4 +1,47 @@ ++ Dealing with relations +++ Many-to-Many relations ++++ Creating a new link +Lets say we have two classes User and Group which are linked trhough a GroupUser association class. When working with transient (new) records the fastest way for adding a User and couple of Groups for it is: + +$user = new User(); +$user->name = 'Some User'; +$user->Group[0]->name = 'Some Group'; +$user->Group[1]->name = 'Some Other Group'; +$user->save(); + + +However in real world scenarious you often already have existing groups, where you want to add a given user. The most efficient way of doing this is: + +$gu = new GroupUser(); +$gu->user_id = $userId; +$gu->group_id = $groupId; +$gu->save(); + + ++++ Deleting a link + +While the obvious and convinient way of deleting a link between User and Group would be the following, you still should *NOT* do this: + + +$user = $conn->getTable('User')->find(5); +$user->GroupUser + ->remove(0) + ->remove(1); + + +The right way to delete links between many-to-many associated records is by using the DQL DELETE statement. Convenient and recommended way of using DQL DELETE is trhough the Query API. + + +$deleted = Doctrine_Query::create() + ->delete() + ->from('GroupUser') + ->addWhere('user_id = 5') + ->whereIn('group_id', $groupIds); + ->execute(); +// print out the deleted links +print $deleted; + + ++ Component overview ++ Fetching objects +++ Field lazy-loading