Forums / Extensions / eZ Find / Filter: could not work with whitespace

Filter: could not work with whitespace

Author Message

Mingxing Chen

Wednesday 30 December 2009 4:42:23 am

Hello all,

I met an intresting issue, and researched the forum, but didn't get the answer.

I set the filter for an attribute, which is the name of folder. Note: there is a whitespace!

{set $search=fetch( ezfind,search,
                        hash( 'query', $search_text,
                              'filter', array( 'folder/name:Mingxing Test') )
                             ))}

Then try to search the text, eg. 'Test'. The process doesn't work well.

But if there is no space between the words which means the name of folder is one word.(e.g Test), it does work.

Anybody can help me?

Thanks very much.

Shinetech is the leader in next generation global application outsourcing. Shinetech combines world class technical skills, recognized expertise in advanced development methodologies and industry experience to deliver results for global enterprises. Shinetech utilizes distributed Agile methods for rapid and precise systems development.
------------------------------------------------------------------------------------------
Blog: http://www.mingxing.me
Email: chenmx@shinetechchina.com

Bertrand Dunogier

Wednesday 30 December 2009 9:18:30 am

First, is "Mingxing test" the full string you are looking for, or is it partial ?

Then, out of curiosity, could you try url encoding the string, or at least replace the space with %20 ?

Bertrand Dunogier
eZ Systems Engineering, Lyon
http://twitter.com/bdunogier
http://gplus.to/BertrandDunogier

Mingxing Chen

Wednesday 30 December 2009 5:19:48 pm

Hi Bertrand, Thanks for your reply.

First, is "Mingxing test" the full string you are looking for, or is it partial ?

>>"Mingxing Test" is the full string as the folder name.

 

Then, out of curiosity, could you try url encoding the string, or at least replace the space with %20 ?

>> I did try, but failed. would youl like to look at the message below which was got by debug:

'Filter' => 
    <b>array</b>
      0 => string 'folder/name:Mingxing%20Test'
'fq' => 
    <b>array</b>
      0 => string '( ((meta_installation_id_s:e8ba26d71fa1af8d15cbe4c687f17b44 AND (( ( meta_section_id_si:1 OR meta_section_id_si:3 )) OR ( ( meta_contentclass_id_si:4 OR meta_contentclass_id_si:44 OR meta_contentclass_id_si:45 OR meta_contentclass_id_si:48 ))))  ) AND ( meta_language_code_s:eng-AU ) ) AND meta_is_invisible_b:false' <i>(length=315)</i>
      1 => string 'meta_contentclass_id_si:1' <i>(length=25)</i>
      2 => string 'meta_language_code_s:eng-AU' <i>(length=27)</i>
      3 => string '( meta_contentclass_id_si:1 AND attr_name_s:Mingxing%20Test )' <i>(length=62)</i>

If I remove the whitespace, it works well.

And there is an example in the document of ezfind:

Example:

fetch( ezfind, search,
hash( query, 'eZ Systems',
filter, array( 'car/in_stock:1',
'car/make:Alfa Romeo',
'car/model:8C' ) ) )

Returns:
Result with documents containing the words “ez” and “systems”, attribute “car/in_stock” with a value of “1”, the “car/make” attribute with the value “alfa romeo” and the “car/model” attribute with the value “8c”.

Let me know what is your opinion. Many thanks.

Shinetech is the leader in next generation global application outsourcing. Shinetech combines world class technical skills, recognized expertise in advanced development methodologies and industry experience to deliver results for global enterprises. Shinetech utilizes distributed Agile methods for rapid and precise systems development.
------------------------------------------------------------------------------------------
Blog: http://www.mingxing.me
Email: chenmx@shinetechchina.com

Bertrand Dunogier

Thursday 31 December 2009 1:36:09 am

I am almost sure that the source of your problem is that ezstring attributes are indexed as 'string' by solr, and string fields have different handling.

I don't have a solution right now, and since I'm on holiday, no Solr to test on (and a new year's eve dinner to cook, too). But what you could do is try manually with the solr backoffice and see what happens: go to http://localhost:8983/solr/select?qt=ezpublish&q=<query>&fq=folder/name:<filter> (replace localhost if necessary, depending on where solr is installed, and replace query with the solr query, and filter with Mingxing Test or anything you want to try it on. You will be able to see in XML what Solr returns exactly, and will know if what is failing is solr or ezfind.

You may also want to check the solr daemon output, from the console, to figure out better what is going on.

Further improvements are planned on strings handling, but it CAN be confusing sometimes ;)

Since you do use the full folder name, I'm guessing that it is not entered manually, right ? If it isn't, and comes from a dropdown or something similar, maybe you could change your filter to use the folder's content object ID ? This would work just fine, and would let you keep moving further for now.

Bertrand Dunogier
eZ Systems Engineering, Lyon
http://twitter.com/bdunogier
http://gplus.to/BertrandDunogier

Mingxing Chen

Thursday 31 December 2009 4:42:49 pm

Hey Bertrand

Many thanks, I will try.

Happy New Year.

Best wishes.

Shinetech is the leader in next generation global application outsourcing. Shinetech combines world class technical skills, recognized expertise in advanced development methodologies and industry experience to deliver results for global enterprises. Shinetech utilizes distributed Agile methods for rapid and precise systems development.
------------------------------------------------------------------------------------------
Blog: http://www.mingxing.me
Email: chenmx@shinetechchina.com

Paul Borgermans

Saturday 02 January 2010 4:19:12 am

The folder/name attribute is most probably configured as a simple string.

In eZ Find up to 2.1, these are indexed by default as a literal string including spaces and other characters and the query syntax for filtering should also take that into account.

So for your query to work, you should add quotes around the string used in filtering too as in the example below:

{set $search=fetch( ezfind,search,  
                      hash( 'query', $search_text, 
                            'filter', array( 'folder/name:"Mingxing Test"') ) )}

FYI

  1. From eZ Find 2.2, there will be the posibility to do the analysis and query time differently for searching/filtering and facets/sorting.
  2. There is also a bug in the ezfind code with respect to generated filter expression in the case of multiple terms, this will be corrected too in ez find 2.2

hth

Paul

eZ Publish, eZ Find, Solr expert consulting and training
http://twitter.com/paulborgermans

Mingxing Chen

Monday 04 January 2010 8:15:05 pm

"

So for your query to work, you should add quotes around the string used in filtering too as in the example below:

{set $search=fetch( ezfind,search,  
                      hash( 'query', $search_text, 
                            'filter', array( 'folder/name:"Mingxing Test"') ) )}
"

Hey Paul

Thank you very much, you pointed out the solution! It works.

I am looking forward to ezfind 2.2~~~ 8-)

/Mingxing

Shinetech is the leader in next generation global application outsourcing. Shinetech combines world class technical skills, recognized expertise in advanced development methodologies and industry experience to deliver results for global enterprises. Shinetech utilizes distributed Agile methods for rapid and precise systems development.
------------------------------------------------------------------------------------------
Blog: http://www.mingxing.me
Email: chenmx@shinetechchina.com

eZ debug

Timing: Jan 18 2025 00:07:49
Script start
Timing: Jan 18 2025 00:07:49
Module start 'content'
Timing: Jan 18 2025 00:07:49
Module end 'content'
Timing: Jan 18 2025 00:07:49
Script end

Main resources:

Total runtime0.2709 sec
Peak memory usage4,096.0000 KB
Database Queries141

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0063 592.1484180.7734
Module start 'content' 0.00630.0042 772.9219111.8047
Module end 'content' 0.01060.2603 884.7266540.3750
Script end 0.2708  1,425.1016 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00331.2323200.0002
Check MTime0.00130.4972200.0001
Mysql Total
Database connection0.00070.248810.0007
Mysqli_queries0.222982.26681410.0016
Looping result0.00140.51341390.0000
Template Total0.259996.010.2599
Template load0.00090.327110.0009
Template processing0.259195.629610.2591
Override
Cache load0.00060.222910.0006
Sytem overhead
Fetch class attribute can translate value0.00080.291210.0008
XML
Image XML parsing0.00030.117410.0003
General
dbfile0.00461.6846200.0002
String conversion0.00000.003130.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