Forums / Developer / Fetching related objects of a specific class

Fetching related objects of a specific class

Author Message

Brian Gerspacher

Friday 11 November 2005 11:43:32 am

I have user groups related to a product and want to retieve only the user groups related to that product (instead of all of the related content objects.) So far I can retieve all of the user groups in the system...

$userGroupClass =& eZContentClass::fetchByIdentifier('user_group');
$conditions = array('contentclass_id' => $userGroupClass->attribute('id'));
$groupObjects =& eZContentObject::fetchList(true, $conditions);

...and I know how to get all of the objects related to the product...

$productObject =& eZContentObject->fetch($myProductId);
$relatedObjects =& $productObject->relatedContentObjectArray();

...but I don't know how to get only the user groups related to the product. Is there an intuitive way to do this, or will I have to take one of the above approaches and loop over the results to pick out the objects I want?

Clemens T

Friday 11 November 2005 4:57:07 pm

I'd say just loop the related-objects array and create a new array and fill it with the object you want:

(pseudo code)

$myFilteredRelatedObject=array();
foreach($relatedObjects as $related)
{
      if($related->attribute('class_identifier')=='my_class_id')
      {
             $myFilteredRelatedObject[]=$related;
      }
}//$myFilteredRelatedObject contains the filtered objects.

off course this is pseudo code, but something like this should work (and yes.. I know that your approch is 'cleaner'.. but don't have any ez code here.. so can't check the ez classes.. that's why my answer is probably incomplete).

Good luck!
Clemens

eZ debug

Timing: Jan 31 2025 06:12:56
Script start
Timing: Jan 31 2025 06:12:56
Module start 'content'
Timing: Jan 31 2025 06:12:56
Module end 'content'
Timing: Jan 31 2025 06:12:57
Script end

Main resources:

Total runtime0.3164 sec
Peak memory usage2,048.0000 KB
Database Queries141

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0057 588.0625180.8125
Module start 'content' 0.00570.0064 768.875093.9453
Module end 'content' 0.01210.3042 862.8203522.8750
Script end 0.3164  1,385.6953 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00381.2153200.0002
Check MTime0.00150.4831200.0001
Mysql Total
Database connection0.00070.210110.0007
Mysqli_queries0.264083.41421410.0019
Looping result0.00140.44091390.0000
Template Total0.303896.010.3038
Template load0.00100.322610.0010
Template processing0.302795.667010.3027
Override
Cache load0.00070.231610.0007
Sytem overhead
Fetch class attribute can translate value0.00120.374710.0012
XML
Image XML parsing0.00030.104310.0003
General
dbfile0.00983.0839200.0005
String conversion0.00000.002330.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 1
 Number of unique templates used: 1

Time used to render debug report: 0.0001 secs