Sphinx关于DOCID_MAX ids的问题 27 September 2011 11:22 Tuesday by 小屋 分享收藏

WARNING: DOCID_MAX document_id, skipping

在window下的Sphinx重建索引的时候一直提示这个notice,导致大部分数据被过滤未成功索引。

原因是数据库的主键字段是20位的BIGINT,超出了Sphinx的32位版本的DOCID_MAX( 4294967295)的限定。

for 64 bit mashines
#define DOCID_MAX       U64C(0xffffffffffffffff)  要小于18446744073709551615
for 32 bit mashines
#define DOCID_MAX       0xffffffffUL 要小于 4294967295

 

解决办法:

如果是linux环境下,根据官方手册说的,带参数:–enable-id64 option 重新编译Sphinx 即可。

如果是window环境,在官方下载编译好了的64bit的版本(Win32 binaries w/MySQL+PgSQL+libstemmer+id64 support):http://sphinxsearch.com/downloads/beta/

 

P,当初下载没注意看浪费半天才搞清楚这问题。

作者: Sjolzy

--EOF--

引用地址:

相关评论:

  1. gravatar face
    宅男 9 月 30 日 对 “Sphinx关于DOCID_MAX ids的问题” 发表最新评论。
    正在学习PHP中~

    正在学习PHP中~

      评分:5

  2. 3
    宅男 :

    正在学习PHP中~

    博主2011-10-03 09:45回复:加油
  3. 2
    北京婚纱照 :

    博主你真的值得大家去顶你。我看你的PHP了。写得真的是有深度。顶你

  4. 1
    bet365 :

    写的非常好 感谢楼主 ~GOOD JOB~

发表评论:

  给 “Sphinx关于DOCID_MAX ids的问题” 评分

广告、无意义的评论必删!