sphinx安裝

相關命令及步驟
    建立主索引:
        /usr/local/coreseek/bin/indexer -c /usr/local/coreseek/etc/csft.conf --all
    建立增量索引:
        1. 建立測試數據表以及數據
        2. 修改配置文件
            主索引源:sql_query_pre
            增量索引源:sql_query_pre  sql_query  sql_query_post
            主索引:source path
            增量索引:source path
        3. 建立/更新主索引
        4. 建立/更新增量索引
        /usr/local/coreseek/bin/indexer -c /usr/local/coreseek/etc/csft.conf delta
    重啓索引進程
        /usr/local/coreseek/bin/searchd --stop
        /usr/local/coreseek/bin/searchd -c /usr/local/coreseek/etc/csft.conf
    索引合併
        /usr/local/coreseek/bin/indexer -c /usr/local/coreseek/etc/csft.conf --merge main delta --rotate


csft.conf配置文件
    source src1
    {
        type                    = mysql
        sql_host                = 127.0.0.1
        sql_user                = root
        sql_pass                =
        sql_db                  = test
        sql_port                = 3306  # optional, default is 3306

        sql_query_pre           = SET NAMES utf8
        sql_query_pre           = REPLACE INTO sph_counter SELECT 1, MAX(id) FROM documents

        sql_query               = \
            SELECT id, group_id, UNIX_TIMESTAMP(date_added) AS date_added, title, content \
            FROM documents

        sql_attr_uint           = group_id

        sql_attr_timestamp      = date_added

        sql_ranged_throttle = 0

        sql_query_info      = SELECT * FROM documents WHERE id=$id

    }

    index test1
    {
        source          = src1

        path            = /usr/local/coreseek/var/data/test1

        docinfo         = extern

        mlock           = 0

        morphology      = none

        stopwords           = /usr/local/coreseek/var/data/test1/stopwords.txt

        wordforms           = /usr/local/coreseek/var/data/test1/wordforms.txt

        min_word_len        = 1

        charset_type        = sbcs

        html_strip              = 0

    }

    source delta : src1
    {
        sql_query_pre = SET NAMES utf8
        sql_query = SELECT \
                        id, group_id, UNIX_TIMESTAMP(date_added) AS date_added, title, content \
                    FROM documents \
                    WHERE \
                        id>( SELECT max_doc_id FROM sph_counter WHERE counter_id=1 )
        sql_query_post = UPDATE sph_counter SET max_doc_id=(SELECT MAX(id) FROM documents) where counter_id=1
    }

    index delta : test1
    {
        source = delta
        path = /usr/local/coreseek/var/data/test1
    }


建立mysql測試數據表及數據
    CREATE TABLE `documents` (`id` int(11) NOT NULL auto_increment,`group_id` int(11) NOT NULL,`group_id2` int(11) NOT NULL,`date_added` datetime NOT NULL,`title` varchar(255) NOT NULL,`content` text NOT NULL,PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=5;

    INSERT INTO `documents` VALUES ('1', '1', '5', '2008-09-13 21:37:47', 'test one', 'this is my test document number one. also checking search within phrases.');INSERT INTO `documents` VALUES ('2', '1', '6', '2008-09-13 21:37:47', 'test two', 'this is my test document number two');INSERT INTO `documents` VALUES ('3', '2', '7', '2008-09-13 21:37:47', 'another doc', 'this is another group');INSERT INTO `documents` VALUES ('4', '2', '8', '2008-09-13 21:37:47', 'doc number four', 'this is to test groups');

    // 實現增量索引時使用的計數表
    CREATE TABLE sph_counter( counter_id INTEGER PRIMARY KEY NOT NULL, max_doc_id INTEGER NOT NULL);



PHP使用

    <?php

    header("Content-type: text/html; charset=utf-8");

    require_once('sphinxapi.php');

    $s = new SphinxClient();

    $s->setServer("127.0.0.1", 9312);
    $s->setArrayResult(true);
    $s->setMatchMode(SPH_MATCH_ALL);

    $keyword = 'test';

    $result = $s->Query($keyword, '*');
    if ($result['total'] == 0) {
        echo '無搜索結果';die;
    }

    // 獲取結果id集
    $ids = array();
    foreach($result['matches'] as $key => $val)
    {
        $ids[] = $val['id'];
    }
    print_r($ids);

    // 鏈接數據庫
    $dsn = "mysql:host=localhost;dbname=test;charset=utf8";
    $db = new PDO($dsn, 'root', '');

    $sql = 'select * from documents where id in('.implode(',', $ids).')';
    $result = $db->query($sql);
    $result->setFetchMode(PDO::FETCH_ASSOC);

    $data = $result->fetchAll();

    // 搜索結果高亮顯示
    $rule = array(
                "before_match" => "<font style='font-weight:bold;color:#f00'>",
                "after_match" => "</font>"
            );
    foreach ($data as $key=>$val) {
        $data[$key] = $s->BuildExcerpts($val, 'delta', $keyword, $rule);
    }

    print_r($data);



添加新分詞
    1. 複製unigram.txt文件爲unigram_new.txt
    2. 在unigram_new.txt中添加新詞
    3. 生成新的詞典文件:/usr/local/mmseg3/bin/mmseg -u /usr/local/mmseg3/etc/unigram_new.txt
    4. 替換原有的uni.lib文件
    5. 重建索引 && 重啓索引php

相關文章
相關標籤/搜索