相關命令及步驟
建立主索引:
/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