刚接触使用sphinx,读了些资料,现在就把我所理解到的记录下:
1:修改sphinx.conf文件后,需要重新建立索引,查询才会生效,所谓的全文索引查找,就是在setfilter后(相当于sql的where条件),query('content','index‘);
(1):content代表要查询的文字。(2):index是建立的要查询的索引
找到匹配的结果。
2:当我们使用API从sphinx执行了一个查询之后,接口会返回一个数组。在这个数组中存在total_found和total两个值。
当查询出的结果数小于sphin中配置的最大返回结果数(默认为1000)时,这两个值是相等的。
而查询出的结果数大于sphin中配置的最大返回结果数(默认为1000)时,total_found的值是在sphinx中所有满足搜索条件的结果数,而total返回的是sphin中配置的最大返回值。
因此,在分页等需要所有满足搜索条件的结果数的时候,应该使用total_found的值。
3:代码实例如下
require(“sphinxapi.php”); //加载类文件
$cl=new SphinxClient(); //实例化类
$cl->SetServer(‘localhost’,9312); //设置服务
$cl->SetArrayResult(true); //设置 显示结果集方式
$cl->SetLimits(0,10); //同 sql语句中的LIMIT
$cl->SetSortMode(“mode”); //排序模式 SPH_SORT_ATTR_DESC和SPH_SORT_ATTR_ASC
$result=$cl->Query(‘ff’,[索引名称可选]); //执行搜索
Var_dump($result); //输出
4:sphinx建立所以 及监听
切换到 DOS sphinx/bin 目录下
a. 建立索引
Indexer –c sphinx.conf 索引名称/–all (–all参数是建立所有索引)
完成后提示如下:
total 535600 docs, 10707632 bytes
total 34.323 sec, 311958 bytes/sec, 15604.27 docs/sec
total 5 reads, 0.282 sec, 45592.6 kb/call avg, 56.4 msec/call avg
total 547 writes, 12.172 sec, 1017.0 kb/call avg, 22.2 msec/call avg
b. 建立完成后
可以执行 search [–c] sphinx.conf 搜索内容 (-c参数:是否允许模糊搜索)
c. 监听端口
Searchd
运行后 提示
listening on all interfaces, port=9312
accepting connections
监听成功后 既可以运行PHP程序 进行 搜索
5:
属性 | 描述 |
---|
sql_attr_uint 和sql_attr_bigint | 32 位无符号整数值和 64 位有符号整数值。可对所有整数数据库字段和 DATE 使用这两种类型。 |
sql_attr_float | 32 位浮点值。如果您想要存储地理坐标,可使用此属性类型。还要注意的是,如果您需要更高的精确度,则没有解决方法;字段四舍五入到七位小数。 |
sql_attr_bool | 一个布尔型(单个位)值,类似于 MySQL 的 tinyint 值。 |
sql_attr_timestamp | 一种 UNIX 时间戳,可表示从 1970-01-01 到 2038-01-19 的日期/时间值。您在 Sphinx 中无法直接使用 DATE 或 DATETIME 列类型。您必须使用 UNIX_TIMESTAMP() 函数将它们转换为时间戳。如果您仅需要日期,可使用 TO_DAYS() 函数将 DATE 字段转换为一个整数。 |
sql_attr_string 和sql_field_string | 字符串(很明显!),但前者仅用于检索,而后者可作为全文本被索引。 |
6:
如何改变Sphinx搜索的Total最大限制值
Sphinx搜索匹配的总数默认为1000。不过,你可以修改成任意值。官方建议是1,000 - 10,000 之间。
修改Sphinx搜索匹配总数的方法
假如你希望搜索匹配总数为 8000
1) Sphinx.conf(修改配置文件需要重新建立索引)
max_matches = 8000 <-修改成你希望的值
2)sphinxapi.php
$this->_maxmatches
= 8000; //改成希望的值
3)Sphinx客户端调用
sphinxClient.SetLimits(0,10, 8000); <-修改第三个参数
sphinx服务启动