天天看點

mysql複合屬性,sphinx中複合屬性字段sql_attr_multi的用法

‍‍sql_attr_multi在sphinx可以用來檢索有層級關系的資料,效率相當高,如,在資料庫中用一個4層的分類,分類下對應着不用的文章,現在需要做一個文章清單,要求,選擇第一級分類時屬于它的子分類的文章也要顯示出來,就可以用下面的方法建索引‍‍sql_query= \

SELECT di.company_document_id as id,di.company_document_id, \

di.title as title_attr, di.content as content_attr, \

di.sort, di.weixin_company_id,\

di.is_show,\

di.mod_time,\

dc.category_id, dc.document_type, \

CONCAT(IF(dc.`category_id` is NULL,0,dc.`category_id`),',',IF(dc2.`category_id` is NULL,0,dc2.`category_id`),',',IF(dc3.`category_id` is NULL,0,dc3.`category_id`),',',IF(dc4.`category_id` is NULL,0,dc4.`category_id`)) AS category_ids \

FROM test_company_document di \

LEFT JOIN  crm_company_document_category dc ON dc.category_id = di.category_id \

LEFT JOIN  test_company_document_category dc2 ON dc.parent_id = dc2.category_id \

LEFT JOIN  test_company_document_category dc3 ON dc2.parent_id = dc3.category_id \

LEFT JOIN  test_company_document_category dc4 ON dc3.parent_id = dc4.category_id \

WHERE di.is_show =1 AND di.is_delete = 0 \

AND di.company_document_id>=$start AND di.company_document_id<=$end

sql_query_range        = SELECT MIN(company_document_id),MAX(company_document_id) FROM test_company_document

sql_range_step        = 1000

然後用下面的方法建立sql_attr_multi屬性字段:

sql_attr_multi = uint category_ids from field category_ids

生成索引後,表中的資料如下:category_ids...

0,1,2,3...

0,1...

本文原創于phpsir的新浪部落格 (phpsir的發現與總結 http://blog.sina.com.cn/phpsir),未經本人允許禁止轉載。

即可用:filter=category_ids,1的方式檢索在不同層級分類下的文章。

另外,也可以用下面的文法建立sql_attr_multi字段:# sql_attr_multi            = uint atags from ranged-query; \

#    SELECT d.company_document_id,da.category_name FROM test_company_document_category da \

#            INNER JOIN test_company_document d ON d.category_id = da.category_id \

#            WHERE d.company_document_id>=$start AND d.company_document_id<=$end ORDER BY d.company_document_id ASC;\

#    SELECT MIN(company_document_id),MAX(company_document_id) FROM test_company_document;