2012-07-09 325 views
1

我遇到了Sphinx搜索索引问题。我一直从它得到空的结果集。Sphinx搜索索引

source mrc 
{ 
    type  = mysql 
    sql_host = localhost 
    sql_user = root 
    sql_pass = 
    sql_db = test_db 
    sql_port = 3306 
    mysql_connect_flags = 32 

    sql_query_pre = SET NAMES latin1 
    sql_query_pre = SET SESSION query_cache_type=OFF 
    sql_query_pre = REPLACE INTO sphinx.indexer (idx,server,version,lastrun_at) SELECT 'mrc','localhost','2.0.4',UNIX_TIMESTAMP(NOW()) FROM DUAL 
    sql_query_post = UPDATE sphinx.indexer SET fetched_by = UNIX_TIMESTAMP(NOW()) WHERE idx = 'mrc' AND server = 'localhost' AND version = '2.0.4' 
    sql_query_post_index = UPDATE sphinx.indexer SET indexed_by = UNIX_TIMESTAMP(NOW()) WHERE idx = 'mrc' AND server = 'localhost' AND version = '2.0.4' 

    sql_attr_uint = mrc_id 
    sql_attr_uint = mrc_parent 
    sql_attr_float = mrc_latitude 
    sql_attr_float = mrc_longitude 

    sql_query = \ 
     SELECT mrc_id AS doc_id, \ 
     mrc_id, \ 
     mrc_parent, \ 
     RADIANS(mrc_latitude) as mrc_latitude, \ 
     RADIANS(mrc_longitude) as mrc_longitude \ 
     FROM mrc_table \ 
     WHERE mrc_parent > 0 

    sql_query_info = SELECT * FROM mrc_table WHERE mrc_id = $id 

} 

index mrc 
{ 
    charset_type = sbcs 
    docinfo = extern 
    mlock = 1 
    morphology = none 
    source = mrc 
    path = /usr/local/var/data/mrc 
} 

索引给我 -

indexing index 'member_region_cities'... 
collected 78312 docs, 0.0 MB 
total 78312 docs, 0 bytes 
total 0.656 sec, 0 bytes/sec, 119354.57 docs/sec 

如果我通过连接mysql的到searchd,做

SELECT * FROM mrc_table; 

它返回空。

的Theres肯定是在本地主机表中的数据,你可以看到它在索引说“收集78312”

那么,为什么不狮身人面像将数据放入searchd的?

干杯

回答

2

我发现我的问题,我没有选择任何领域。我将所有的列配置为属性。 sql_attr_uint = mrc_id

以供将来参考,如果需要的索引而不字段可以设置一个虚拟字段例如 -

我通过丢弃该线固定此将 - 'a'添加为选择查询。

2

请仔细检查您的问题。您为索引提供了配置,名为mrc但索引器输出显示为member_region_cities但我相信这只是缩短的名称。

  1. 请确保您运行--rotate选项索引如果searchd的启动和运行。

  2. 您可以检查文件ID的数量使用

    ./indextool --dumpheader /usr/local/var/data/mrc.sph指数|用grep总文件

  3. 请确保您连接到狮身人面像服务器,而不是到MySQL通常它是在9306端口

    的mysql -h 127.0.0.1 -P 9306

运行希望这可以帮助

+0

不错,我在发布之前将索引中的所有member_region_cities替换为mrc,这就是索引器输出的原因。 索引工具输出 - 总文件:78312,并感谢您的提示,我不知道索引工具 而且肯定连接到正确的服务器。 – Marklar 2012-07-09 20:01:47

+0

那么SELECT * FROM mrc仍然是空的? – vfedorkov 2012-07-10 08:27:32

+0

您使用哪个Sphinx版本? – vfedorkov 2012-07-10 08:36:02