News Feed
Jobs Feed
Sections




News Archive
Ralph Schindler's Blog:
Composite Rowsets For Many-To-Many Relationships Via Zend_Db_Table
November 16, 2010 @ 11:08:24

Ralph Schindler has posted a handy tutorial (along with some helpful code) to his blog today about handling many-to-many composite rowset relationships with the Zend_Db component of the Zend Framework.

One of the hardest problems to solve when developing an ORM of any complexity is in deciding how to handle the retrieval of rows that satisfy a many-to-many relationship, also known as a M:N relationship. [...] To model M:N relationships, database developers must get creative. By employing the use of a "3rd party", and by utilizing foreign keys that model a 1:N relationship, database developers can model a M:N relationship.

He looks at the Zend_Db_Table_Row class of the framework and how it works with these junction tables and how it has an issue where it returns the junction table columns too. A fix was released (in 1.10.2) for the framework to work correctly. Unfortunately, this also left those using the method out in the cold. So, Ralph has created his own workaround called a composite rowset. He includes an example snippet to give you an idea of how it works, but you can download the code from his github repository for a closer look.

0 comments voice your opinion now!
composite rowset zendframework zenddbtable manytomany database


blog comments powered by Disqus

Similar Posts

Doug Brown's Blog: Zend Framework vs CakePHP Framework

Maggie Nelson's Blog: php|architect: Database Design for PHP Programmers by Mac Newbold

Roshan Bhattarai's Blog: Which is the best PHP framework ?

IBM developerWorks: Batch processing in PHP

Rob Allen's Blog: Zend Framework Tutorial Zip File Updated


Community Events









Don't see your event here?
Let us know!


language community phpunit example testing api opinion introduction release zendframework2 functional database unittest framework object development event code interview composer

All content copyright, 2013 PHPDeveloper.org :: info@phpdeveloper.org - Powered by the Solar PHP Framework