Forums / General / attribute_filter and two "like"

attribute_filter and two "like"

Author Message

Philippe VINCENT-ROYOL

Wednesday 09 January 2008 6:08:53 am

Hi,

I've a problem with a fetch function.. I want to concat this two lines but it does nt work ..

$children=fetch( 'content', 'tree', hash( 'parent_node_id',$metiers_node.node_id, 'sort_by',array( 'name', true()), 'class_filter_type','include',
'class_filter_array',array( 'job', 'chained_article' ),
'attribute_filter', array( array('job/title' ,'like', $montitre) ) ) )

$children=fetch( 'content', 'tree', hash( 'parent_node_id',$metiers_node.node_id, 'sort_by',array( 'name', true()), 'class_filter_type','include',
'class_filter_array',array( 'job', 'chained_article' ),
'attribute_filter', array( array('chained_article/title' ,'like', $montitre) ) ) )

It work when i use only the first or the second.. But when i try:

$children=fetch( 'content', 'tree', hash( 'parent_node_id',$metiers_node.node_id, 'sort_by',array( 'name', true()), 'class_filter_type','include',
'class_filter_array',array( 'job', 'chained_article' ),
'attribute_filter', array( 'or', array('job/title' ,'like', $montitre), array('chained_article/title', 'like', $montitre) ) ) )

They are no answer :/

What i m doing wrong?

Thanks

Certified Developer (4.1): http://auth.ez.no/certification/verify/272607
Certified Developer (4.4): http://auth.ez.no/certification/verify/377321

G+ : http://plus.tl/dspe
Twitter : http://twitter.com/dspe

Heath

Wednesday 09 January 2008 6:24:23 am

Hello Philippe,

Welcome to the eZ Ecosystem!

I've not read your code, yet this post seems very similar in subject. I think I covered this with detailed examples recently.

<i>http://ezpedia.org/wiki/en/ez/solution_how_to_do_an_attribute_filter_using_the_like_condition
http://ez.no/developer/forum/developer/attribute_filter_breaking_fetch</i>

Cheers,
Heath

Brookins Consulting | http://brookinsconsulting.com/
Certified | http://auth.ez.no/certification/verify/380350
Solutions | http://projects.ez.no/users/community/brookins_consulting
eZpedia community documentation project | http://ezpedia.org

Philippe VINCENT-ROYOL

Wednesday 09 January 2008 6:31:23 am

Hello Heath,

Thanks for your reply. But i ve already read your link and i cant find why i want finally ..

Certified Developer (4.1): http://auth.ez.no/certification/verify/272607
Certified Developer (4.4): http://auth.ez.no/certification/verify/377321

G+ : http://plus.tl/dspe
Twitter : http://twitter.com/dspe

Heath

Wednesday 09 January 2008 6:47:47 am

My concern is not with your broken English, it is with your insistence to combine 'class_filter_array' and 'attribute_filter' which I have never seen work successfully within a single fetch.

I think you would be best served in seeking another solution.

Remember 'attribute_filter' is more powerful than 'class_filter_array'. Meaning you don't need the class filter if your using attribute filter because the attribute filter by it's own nature includes it's own class filter internally ... from what I have seen in dev.

Cheers,
Heath

Brookins Consulting | http://brookinsconsulting.com/
Certified | http://auth.ez.no/certification/verify/380350
Solutions | http://projects.ez.no/users/community/brookins_consulting
eZpedia community documentation project | http://ezpedia.org

Philippe VINCENT-ROYOL

Wednesday 09 January 2008 6:47:50 am

ive found a solution:

$children1=fetch( 'content', 'tree', hash( 'parent_node_id',$metiers_node.node_id, 'sort_by',array( 'name', true()), 'class_filter_type','include',
'class_filter_array',array( 'job', 'chained_article' ),
'attribute_filter', array( array('job/title' ,'like', $montitre) ) ) )

$children2=fetch( 'content', 'tree', hash( 'parent_node_id',$metiers_node.node_id, 'sort_by',array( 'name', true()), 'class_filter_type','include',
'class_filter_array',array( 'job', 'chained_article' ),
'attribute_filter', array( array('chained_article/title' ,'like', $montitre) ) ) )

$children=merge($children1, $children2)

And it works..

Thanks.

Certified Developer (4.1): http://auth.ez.no/certification/verify/272607
Certified Developer (4.4): http://auth.ez.no/certification/verify/377321

G+ : http://plus.tl/dspe
Twitter : http://twitter.com/dspe

André R.

Wednesday 09 January 2008 9:48:57 am

The correct thing would be (using code tags so others even bother reading you code..):

{def $children1 = fetch( 'content', 'tree', hash(
        'parent_node_id', $metiers_node.node_id,
        'sort_by', array( 'name', true()),
        'class_filter_type', 'include', 
        'class_filter_array', array( 'job' ), 
        'attribute_filter', array( array('job/title' ,'like', $montitre) )
       ) ) 
       $children2 = fetch( 'content', 'tree', hash(
        'parent_node_id', $metiers_node.node_id,
        'sort_by', array( 'name', true()),
        'class_filter_type', 'include', 
        'class_filter_array', array( 'chained_article' ), 
        'attribute_filter', array( array('chained_article/title' ,'like', $montitre) )
       ) ) 
       $children = merge( $children1, $children2 )}

Heath: It's true that attribute filter will effectively filter classes as well, but index wise I think using a class filter as well is faster on large dataset. But this depend on the indexes on the ezcontentobject_attribute table, haven't looked at it for a while.
Ref:
http://pubsvn.ez.no/nextgen/trunk/kernel/classes/ezcontentobjecttreenode.php
Search for "function createAttributeFilterSQLStrings".

eZ Online Editor 5: http://projects.ez.no/ezoe || eZJSCore (Ajax): http://projects.ez.no/ezjscore || eZ Publish EE http://ez.no/eZPublish/eZ-Publish-Enterprise-Subscription
@: http://twitter.com/andrerom

Philippe VINCENT-ROYOL

Tuesday 15 January 2008 3:07:48 am

Thanks it works ;)

Certified Developer (4.1): http://auth.ez.no/certification/verify/272607
Certified Developer (4.4): http://auth.ez.no/certification/verify/377321

G+ : http://plus.tl/dspe
Twitter : http://twitter.com/dspe

Piotr Switkowski

Sunday 03 February 2008 1:51:21 pm

Well, doing two separate fetches and merging results is not the same thing as doing one fetch. The real difference is performance. Let assume, you implemented paging on your website. With single fetch you need to retrieve only few objects for one page. With two fetches and merging you need to retrieve all fitting objects. Also, with merging you cannot sort in database. If you want the result sorted, you need to sort in your template code.

All in all, I cannot understand, why attribute_filter is not supporting attribute filtering on attributes from different classes with 'or'. Should this be registered as ezPublish bug?

eZ debug

Timing: Jan 18 2025 10:26:47
Script start
Timing: Jan 18 2025 10:26:47
Module start 'content'
Timing: Jan 18 2025 10:26:48
Module end 'content'
Timing: Jan 18 2025 10:26:48
Script end

Main resources:

Total runtime0.8641 sec
Peak memory usage4,096.0000 KB
Database Queries213

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0068 588.8203180.8438
Module start 'content' 0.00690.7238 769.6641710.9141
Module end 'content' 0.73070.1333 1,480.5781348.4766
Script end 0.8639  1,829.0547 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00420.4858210.0002
Check MTime0.00140.1631210.0001
Mysql Total
Database connection0.00100.114910.0010
Mysqli_queries0.767288.79072130.0036
Looping result0.00250.29322110.0000
Template Total0.831496.220.4157
Template load0.00220.252320.0011
Template processing0.829295.962820.4146
Template load and register function0.00010.011610.0001
states
state_id_array0.00080.090410.0008
state_identifier_array0.00140.167120.0007
Override
Cache load0.00190.2202670.0000
Sytem overhead
Fetch class attribute can translate value0.00120.134750.0002
Fetch class attribute name0.00110.1269110.0001
XML
Image XML parsing0.00210.238550.0004
class_abstraction
Instantiating content class attribute0.00000.0029150.0000
General
dbfile0.00660.7651420.0002
String conversion0.00000.000630.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
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
7content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
8content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
16content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
8content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 42
 Number of unique templates used: 7

Time used to render debug report: 0.0002 secs