Hmm, the right results are coming through... what happens if the store_ids in 
the filter are [41], or [12, 41]?

-- 
Pat

On 19/10/2010, at 3:01 AM, Tyler Smith wrote:

> Thanks for the recommendation, Here is the response.
> 
> mysql> SELECT `products`.`id` AS `product_id`,
>    ->   GROUP_CONCAT(DISTINCT IFNULL(`stores`.`id`, '0') SEPARATOR
> ',') AS `store_ids`
>    ->   FROM `products`
>    ->   LEFT OUTER JOIN `product_stores` ON (`products`.`id` =
> `product_stores`.`product_id`)
>    ->   LEFT OUTER JOIN `stores` ON (`stores`.`id` =
> `product_stores`.`store_id`)
>    ->   WHERE `products`.`id` = 72071
>    ->   GROUP BY `products`.`id`;
> +------------+-------------------+
> | product_id | store_ids         |
> +------------+-------------------+
> |      72071 | 12,39,40,41,15,38 |
> +------------+-------------------+
> 1 row in set (0.02 sec)
> 
> 
> On Oct 15, 8:31 pm, Pat Allan <[email protected]> wrote:
>> Right, not spotting anything obviously wrong there... but let's double-check 
>> the SQL for that attribute and product. Try running the following from 
>> script/dbconsole (but keep in mind I've built it without testing - as it's 
>> your db :)
>> 
>>   SELECT `products`.`id` AS `product_id`,
>>   GROUP_CONCAT(DISTINCT IFNULL(`stores`.`id`, '0') SEPARATOR ',') AS 
>> `store_ids`
>>   FROM `products`
>>   LEFT OUTER JOIN `product_stores` ON (`products`.`id` = 
>> `product_stores`.`product_id`)
>>   LEFT OUTER JOIN `stores` ON (`stores`.`id` = `product_stores`.`store_id`)
>>   WHERE `products`.`id` = 1000
>>   GROUP BY `products`.`id`;
>> 
>> What's the stores_id value?
>> 
>> --
>> Pat
>> 
>> On 16/10/2010, at 2:29 AM, Tyler Smith wrote:
>> 
>> 
>> 
>>> source product_core_0
>>> {
>>>  type = mysql
>>>  sql_host = [FILTERED]
>>>  sql_user = [FILTERED]
>>>  sql_pass = [FILTERED]
>>>  sql_db = [FILTERED]
>>>  sql_sock = /var/run/mysqld/mysqld.sock
>>>  sql_query_pre = SET NAMES utf8
>>>  sql_query_pre = SET TIME_ZONE = '+0:00'
>>>  sql_query = SELECT SQL_NO_CACHE `products`.`id` * 3 + 1 AS `id` ,
>>> `products`.`name` AS `name`, `products`.`brand` AS `brand`,
>>> `products`.`id` AS `sphinx_internal_id`, 485965105 AS `class_crc`, 0
>>> AS `sphinx_deleted`, IFNULL(`products`.`name`, '') AS `name_sort`,
>>> `products`.`id` AS `id`, `products`.`kosher_id` AS `kosher_id`,
>>> `products`.`gluten_free_id` AS `gluten_free_id`,
>>> `products`.`lactose_free_id` AS `lactose_free_id`,
>>> GROUP_CONCAT(DISTINCT IFNULL(`stores`.`id`, '0') SEPARATOR ',') AS
>>> `store_ids`, GROUP_CONCAT(DISTINCT IFNULL(`locations`.`id`, '0')
>>> SEPARATOR ',') AS `location_ids`, GROUP_CONCAT(DISTINCT
>>> IFNULL(`categories`.`id`, '0') SEPARATOR ',') AS `category_ids`,
>>> `koshers`.`passover` AS `kosher_passover` FROM `products`    LEFT
>>> OUTER JOIN `product_stores` ON (`products`.`id` =
>>> `product_stores`.`product_id`)  LEFT OUTER JOIN `stores` ON
>>> (`stores`.`id` = `product_stores`.`store_id`)   LEFT OUTER JOIN
>>> `product_locations` ON (`products`.`id` =
>>> `product_locations`.`product_id`)  LEFT OUTER JOIN `locations` ON
>>> (`locations`.`id` = `product_locations`.`location_id`)   LEFT OUTER
>>> JOIN `category_products` ON (`products`.`id` =
>>> `category_products`.`product_id`)  LEFT OUTER JOIN `categories` ON
>>> (`categories`.`id` = `category_products`.`category_id`)   LEFT OUTER
>>> JOIN `koshers` ON `koshers`.id = `products`.kosher_id  WHERE
>>> `products`.`id` >= $start AND `products`.`id` <= $end GROUP BY
>>> `products`.`id`  ORDER BY NULL
>>>  sql_query_range = SELECT IFNULL(MIN(`id`), 1), IFNULL(MAX(`id`), 1)
>>> FROM `products`
>>>  sql_attr_uint = sphinx_internal_id
>>>  sql_attr_uint = class_crc
>>>  sql_attr_uint = sphinx_deleted
>>>  sql_attr_uint = id
>>>  sql_attr_uint = kosher_id
>>>  sql_attr_uint = gluten_free_id
>>>  sql_attr_uint = lactose_free_id
>>>  sql_attr_bool = kosher_passover
>>>  sql_attr_str2ordinal = name_sort
>>>  sql_attr_multi = uint store_ids from field
>>>  sql_attr_multi = uint location_ids from field
>>>  sql_attr_multi = uint category_ids from field
>>>  sql_query_info = SELECT * FROM `products` WHERE `id` = (($id - 1) /
>>> 3)
>>> }
>> 
>>> index product_core
>>> {
>>>  source = product_core_0
>>>  path = [FILTERED]/releases/20101008215652/db/sphinx/staging/
>>> product_core
>>>  charset_type = utf-8
>>> }
>> 
>>> index product
>>> {
>>>  type = distributed
>>>  local = product_core
>>> }
>> 
>>> On Oct 14, 5:34 pm, Pat Allan <[email protected]> wrote:
>>>> Hi Tyler
>> 
>>>> What does the source for the product model look like in your 
>>>> config/development.sphinx.conf file? (Make sure you remove your database 
>>>> password).
>> 
>>>> Cheers
>> 
>>>> --
>>>> Pat
>> 
>>>> On 15/10/2010, at 4:42 AM, Tyler Smith wrote:
>> 
>>>>> In my Product.rb
>> 
>>>>> define_index do
>>>>>    indexes :name, :sortable => true
>>>>>    indexes brand
>> 
>>>>>    has :id, kosher_id, gluten_free_id, lactose_free_id
>>>>>    has stores(:id),        :as => 'store_ids'
>>>>>    has locations(:id),     :as => 'location_ids'
>>>>>    has categories(:id),    :as => 'category_ids'
>>>>>    has kosher(:passover),  :as => 'kosher_passover'
>>>>>  end
>> 
>>>>> In my Searching Class
>> 
>>>>> def self.for_locations_by_query(query, options = {})
>>>>>    query, categories = @@coder.decode(query).gsub(/(\b\w+\b)/, "+\
>>>>> \0"), @@coder.decode(options.delete(:categories))
>>>>>    origin, page = @@coder.decode(options.delete(:origin)),
>>>>> @@coder.decode(options.delete(:page))
>>>>>    per_page, sort_order = @@coder.decode(options.delete(:per_page)),
>>>>> @@coder.decode(options.delete(:sort_order))
>>>>>    distance, classifications =
>>>>> @@coder.decode(options.delete(:distance)),
>>>>> @@coder.decode(options.delete(:classifications))
>> 
>>>>>    with                        = {}
>>>>>    with[:store_ids]            = Location.all(:origin =>
>>>>> origin, :within => distance).collect(&:store_id).uniq unless
>>>>> origin.blank? or distance.blank?
>>>>>    with[:category_ids]         = categories.split(',') unless
>>>>> categories.blank?
>> 
>>>>>    without                     = {}
>>>>>    without[:kosher_id]         = 0 if
>>>>> classifications.split(',').include? 'kosher'
>>>>>    without[:gluten_free_id]    = 0 if
>>>>> classifications.split(',').include? 'gluten_free'
>>>>>    without[:lactose_free_id]   = 0 if
>>>>> classifications.split(',').include? 'lactose_free'
>>>>>    without[:kosher_passover]   = 0 if
>>>>> classifications.split(',').include? 'kosher_passover'
>> 
>>>>>    products  = Product.search(query, :with => with, :without =>
>>>>> without, :per_page => 20, :page => 1)
>>>>>    stores    = products.collect { |p| p.stores }.flatten.uniq
>>>>>    locations = stores.collect { |s| s.locations.find(:all, :origin =>
>>>>> origin, :within => distance) }.flatten.uniq
>>>>>    locations.sort_by_distance_from(origin)
>>>>>    locations.each { |l| l.dist = l.distance }
>> 
>>>>>    locations = locations.paginate(:page => page, :per_page =>
>>>>> per_page)
>> 
>>>>>    return { :total_entries => locations.total_entries, :size =>
>>>>> locations.size, :locations => locations }
>>>>>  end
>> 
>>>>> The problematic line is with[:store_ids] = ...
>>>>> The product can be associated to multiple store ids, however it only
>>>>> seems to work if the lowest numbered ID is in the array for
>>>>> with[:store_ids].  For example, the ids associated with product 1000
>>>>> are [12,15,41], if with[:store_ids] = [15,41] then 0 results are
>>>>> returned, however if 12 is in the array then it works.
>> 
>>>>> I have stopped, started, restarted, reindexed, rebuilt, generated a
>>>>> new conf file for sphinx, and repeated in various orders and I have
>>>>> had no luck.
>> 
>>>>> --
>>>>> You received this message because you are subscribed to the Google Groups 
>>>>> "Thinking Sphinx" group.
>>>>> To post to this group, send email to [email protected].
>>>>> To unsubscribe from this group, send email to 
>>>>> [email protected].
>>>>> For more options, visit this group 
>>>>> athttp://groups.google.com/group/thinking-sphinx?hl=en.
>> 
>>> --
>>> You received this message because you are subscribed to the Google Groups 
>>> "Thinking Sphinx" group.
>>> To post to this group, send email to [email protected].
>>> To unsubscribe from this group, send email to 
>>> [email protected].
>>> For more options, visit this group 
>>> athttp://groups.google.com/group/thinking-sphinx?hl=en.
> 
> -- 
> You received this message because you are subscribed to the Google Groups 
> "Thinking Sphinx" group.
> To post to this group, send email to [email protected].
> To unsubscribe from this group, send email to 
> [email protected].
> For more options, visit this group at 
> http://groups.google.com/group/thinking-sphinx?hl=en.
> 

-- 
You received this message because you are subscribed to the Google Groups 
"Thinking Sphinx" group.
To post to this group, send email to [email protected].
To unsubscribe from this group, send email to 
[email protected].
For more options, visit this group at 
http://groups.google.com/group/thinking-sphinx?hl=en.

Reply via email to