Forums / Extensions / eZ Find / eZ Find using sort_by

eZ Find using sort_by

Author Message

Greg Lakomy

Friday 13 February 2009 9:15:37 am

Hi,

I'm running into some issues with eZ Find. No matter how I construct sort_by, it doesn't sort my search results. I want to sort by one of the attributes (date type) but it doesn't seem to work. I've tried both ezFind 1.0 and 2.0 versions and sort_by doesn't work. Unless, I'm doing something wrong.

ez Find 1

{def $search = fetch( 'content', 'search',
		hash( 'text', $search_text,
			  'offset', $view_parameters.offset,
			  'limit', $page_limit,
			  'section_id', 10,
			  'subtree_array', $search_subtree_array,
			  'class_id', array( '49' ),
			  'class_attribute_id', $search_field,			  
			  'sort_by', array('attribute', true(), 412))  ) )}

ez Fidnd 2.0

{def $search = fetch( ezfind, search, 
				hash( 'query', $search_text,
				 	  'offset', $view_parameters.offset,
				  	  'limit', $page_limit,
					  'section_id', 10,
					  'subtree_array', $search_subtree_array,
					  'class_id', array( '49' ),
					  'class_attribute_id', $search_field,	
					  'sort_by', hash(412, 'asc') ) )}

Thanks,
Greg.

Developer
http://www.duoconsulting.com

Graham Tillotson

Wednesday 18 February 2009 2:35:51 pm

Bumping this one -- anyone out there tried the attribute sort with eZ Find? We've been working on it today, and we can get the syntax to work with the internal search engine but not with eZ Find. Some key questions around this:

** should the fetch syntax for attribute sorting work the same with both the internal search engine and eZ Find?

** should the attribute sort parameters work for both standard fetches and those with keyword filters (when searching)?

Any help on this would be greatly appreciated.

DUO : CONSULTING
Web content management experts
www.duoconsulting.com

Nicolas Pastorino

Thursday 19 February 2009 8:36:00 am

Hello,

Here is the supported syntax for the sort_by parameter :

'sort_by', hash( 'published', 'asc',
                         'folder/name', 'asc' )

Should you want to sort by only one criteria, use the similar :

'sort_by', hash( 'article/title', 'asc' )

Hope it helped.
Please note the the 2.0 stable version of eZFind is out now, including nice new features, and, on a sidenote, bugfixes.
http://ez.no/company/news/ez_systems_releases_apache_solr_based_open_source_enterprise_search_solution_ez_find_2_0

Enjoy !

--
Nicolas Pastorino
Director Community - eZ
Member of the Community Project Board

eZ Publish Community on twitter: http://twitter.com/ezcommunity

t : http://twitter.com/jeanvoye
G+ : http://plus.tl/jeanvoye

Graham Tillotson

Friday 20 February 2009 7:54:51 am

Nicolas,

This is excellent -- thank you! We will try the code today. Is this documented anywhere? We used the standard sort syntax, and read through the eZ Find documentation, and we did not see the syntax in your example.

DUO : CONSULTING
Web content management experts
www.duoconsulting.com

Greg Lakomy

Friday 20 February 2009 11:59:46 am

I've tried using that syntex with my install of eZ Find (1.0.0beta2), but still no luck...

Here is my code:

{def $search = fetch( 'content', 'search',
	hash( 'text', $search_text,
		  'sort_by', hash('press_release_page/title', 'asc'),
		  'offset', $view_parameters.offset,
		  'limit', $page_limit,
		  'section_id', 10,
		  'subtree_array', $search_subtree_array,
		  'class_id', array( '49' ),
		  'class_attribute_id', $search_field
		  ) 
	)}

I will try installing new 2.0 next and give you an update...

Developer
http://www.duoconsulting.com

Greg Lakomy

Wednesday 25 February 2009 7:50:15 am

Quick update... I got sort_by working with eZ Find 2.0

Here is my sample:

{def $search = fetch( ezfind, search,
				hash( 'query', $search_text,
				'sort_by', hash('press_release_page/publish_date', desc),
				'offset', $view_parameters.offset,
				'section_id', 10,
				'subtree_array', $search_subtree_array,
				'class_id', array( '49' ),
				'class_attribute_id', $search_field,
				'limit', $page_limit ) ) }

Filters are helpful too:

{def $search = fetch( ezfind, search,
				hash( 'query', $search_text,
				'sort_by', hash('press_release_page/publish_date', desc),
                                'filter', 'press_release_page/country:Japan',
				'offset', $view_parameters.offset,
				'section_id', 10,
				'subtree_array', $search_subtree_array,
				'class_id', array( '49' ),
				'class_attribute_id', $search_field,
				'limit', $page_limit ) ) }

Developer
http://www.duoconsulting.com

Nicolas Pastorino

Tuesday 03 March 2009 1:24:12 am

Hi Greg,

Great to see that you got everything to work !
A small addition to your post, about the power of filters. It has been enhanced in eZ Find 2.0, now supporting any combination of boolean filters. You can get inspiration from http://ez.no/doc/extensions/ez_find. Here is an excerpt :

fetch( ezfind, search, 
       hash( query, 'eZ Systems', 
             filter, array( 'or', 
                            array( 'and', 
                                   'article/body:hello', 
                                   'article/rating:[1 TO 10]' 
                                 ), 
                            array( 'and', 
                                   'article/body:goodbye', 
                                   'article/rating:[10 TO 20]' 
                                 ) 
                          ) 
      ) 

Would you have another piece of feedback on this 2.0 stable release ? Have you pushed it in production yet ?

Thanks and best regards,

--
Nicolas Pastorino
Director Community - eZ
Member of the Community Project Board

eZ Publish Community on twitter: http://twitter.com/ezcommunity

t : http://twitter.com/jeanvoye
G+ : http://plus.tl/jeanvoye

Sylvain Gogel

Friday 27 March 2009 4:15:44 am

ezfind, search is pretty kewl but there is two use cases i cannot acheaves:

<b>Use Case 1:</b>

On a multi content class search ; filter by node.published within a range
something like

'filter', array('published:NOW TO NOW/DAY-30DAY')

To get all content published the last 30 days

this synthax does not work

<b>Use Case 2:</b>

Search multiple classes related to a single theme
This is the school case: News 1--->* Theme
I want to fetch all news that are related to a given theme
Somthing like:

'filter', array( '*/themes/node_id:458')

--
http://www.ecedi.fr
Agence Web, Créa/Conseils, Accessibilité
eZPublish, Drupal, Zend, Symfony

eZ debug

Timing: Jan 18 2025 02:08:37
Script start
Timing: Jan 18 2025 02:08:37
Module start 'content'
Timing: Jan 18 2025 02:08:37
Module end 'content'
Timing: Jan 18 2025 02:08:37
Script end

Main resources:

Total runtime0.1814 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.0072 588.8672180.7891
Module start 'content' 0.00720.0088 769.6563107.0547
Module end 'content' 0.01600.1653 876.7109537.0469
Script end 0.1813  1,413.7578 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00351.9269200.0002
Check MTime0.00140.7690200.0001
Mysql Total
Database connection0.00130.696310.0013
Mysqli_queries0.120866.59091410.0009
Looping result0.00150.83151390.0000
Template Total0.164990.910.1649
Template load0.00090.498010.0009
Template processing0.164090.435810.1640
Override
Cache load0.00060.330210.0006
Sytem overhead
Fetch class attribute can translate value0.00080.439510.0008
XML
Image XML parsing0.00020.130710.0002
General
dbfile0.00532.9145200.0003
String conversion0.00000.003830.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