添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
  • Resources
  • Composer 支持

    自 v1.4.9 起,通过 subtree 功能将 xs-sdk-php 分离成为一个只读的子仓库, 以支持通过 composer 安装。我们的包名称为 hightman/xunsearch ,内含全部 PHP-SDK 的库文件,还包括支持 Yii 的扩展类。

    安装

    和绝大多数 composer 一样,你可以通过以下两种方法中的任意一种安装。

    可以直接运行

    composer require --prefer-dist hightman/xunsearch "*@beta"
    

    或者将以下内容添加到您的项目根目录 composer.json 中的 require 章节, 然后运行 composer install

    "hightman/xunsearch": "*@beta"
    

    Tip: 如果您打算用代码仓库中的最新版本,请将星号改为 dev-master。

    命令行工具
    vendor/bin/xs help
    
    Yii-1.x 用法

    这是对 xunsearch 的一个简单封装,使之更适合 yii-1.x 的用法习惯。首先, 在应用入口文件最开头引入 composer 的 autoload 文件,通常是 index.php。

    require_once 'vendor/autoload.php';
    // 如有必要请定义常量 XS_APP_ROOT 表示项目文件存放路径
    //define ('XS_APP_ROOT', dirname(__FILE__) . '/protected/data');
    

    在应用配置文件的 compnents 中添加以下代码,通常是 protected/config/main.php

    // application components
        'components' => array(
            // ... other components ... 
            'search' => array(
                'class' => 'EXunSearch',
                'project' => 'demo', // 搜索项目名称或对应的 ini 文件路径
                'charset' => 'utf-8', // 您当前使用的字符集(索引、搜索结果)
    

    然后就可以通过 Yii::app()->search 来访问 EXunSearch 对象,进行索引管理或检索。

    添加、修改索引数据,使用方法参照 XSIndex。 对于 ActiveRecord 对象来讲,建议在相关的 afterSaveafterDelete 中进行索引同步。

    $data = array('pid' => 1234, 'subject' => '标题', 'message' => '内容');
    Yii::app()->search->add($data);	// 添加文档
    Yii::app()->search->update($data);	// 更新文档
    Yii::app()->search->del('1234');	// 删除文档
    

    使用检索功能时,可以将 Yii::app()->search 当作 XSSearch 对象一样直接使用它的全部方法。

    Yii::app()->search->setQuery('subject:标题');
    $docs = Yii::app()->search->setLimit(5, 10)->search();	// 取得搜索结果文档集
    
    Yii-2.x 用法

    在 yii2 中,除了提供类似 yii-1.x 的调用方式外,我们还支持 ActiveRecord 方式来操作。首先, 请在应用配置文件的 components 中添加以下代码,通常是 config/web.php

    // application components
    	'components => [
    		// ... other components ...
    		'xunsearch' => [
    			'class' => 'hightman\xunsearch\Connection',	// 此行必须
    			'iniDirectory' => '@app/config',	// 搜索 ini 文件目录,默认:@vendor/hightman/xunsearch/app
    			'charset' => 'utf-8',	// 指定项目使用的默认编码,默认即时 utf-8,可不指定
    

    接下来,你可以通过以下代码获取到 hightman\xunsearch\Database 对象,该对像和 yii-1.x 的 EXunSearch 用法很相似,通过魔术方法,能够依次检索以下对象的方法列表而直接调用:

    $db = \Yii::$app->xunsearch->getDatabase('demo');
    $db = \Yii::$app->xunsearch('demo');
    $xs = $db->xs;
    $search = $db->getSearch();
    $index = $db->getIndex();
    
  • XS 优先调用该对象方法,如有必要,可直接通过 hightman\xunsearch\Database::$xs 属性访问。
  • XSIndex 紧接着检查索引管理方法,如有必要,可直接通过 hightman\xunsearch\Database::$index 属性访问。
  • XSSearch 紧接着检查索引管理方法,如有必要,可直接通过 hightman\xunsearch\Database::$search 属性访问。
  • 具体用法不再赘述,下面重点讲讲如何通过 ActiveRecord 方法来检索和创建索引,由于遵循 yii2 的思想进行开发设计, 使用起来非常方便和简单。

    创建 AR 对象

    首先必须创建一个继承自 hightman\xunsearch\ActiveRecord 的模型类,默认情况下会以全小写的类名字作为 ini 文件名。如需指定,请自行覆盖编写 hightman\xunsearch\ActiveRecord::projectName()。通常代码如下:

    class Demo extends \hightman\xunsearch\ActiveRecord
        /*public static function projectName() {
            return 'another_name';	// 这将使用 @app/config/another_name.ini 作为项目名
    

    由此可见,如果命名规范模型类几乎不需要任何额外代码,上述代码会自动采用 demo.ini 并自动装载字段配置。

    添加或更新索引

    为避免数据重复,底层统一通过 XSIndex::update() 方法进行提交的。

    // 添加索引,也可以通过 $model->setAttributes([...]) 批量赋值
    $model = new Demo;
    $model->pid = 321;
    $model->subject = 'hello world';
    $model->message = 'just for testing...';
    $model->save();
    // 更新索引
    $model = Demo::findOne(321);
    $model->message .= ' + updated';
    $model->save();
    // 添加或更新索引还支持以方法添加索引词或文本
    // 这样做的目的是使得可以通过这些关键词检索到数据,但并非数据的字段值
    // 用法与 XSDocument::addTerm() 和 XSDocument::addIndex() 等同
    // 通常在 ActiveRecord::beforeSave() 中做这些操作
    $model->addTerm('subject', 'hi');
    $model->addIndex('subject', '你好,世界');
    // 如需删除数据则可直接
    $model->delete();
    

    如需要做批量删除或更新,请参见以下代码文档:ActiveRecord::updateAll()ActiveRecord::deleteAll()

    检索对象

    重点先介绍一下 ActiveQuery::where() 系列搜索条件函数的用法,和 yii2 其它的 ActiveRecord 类似:

    $query = Demo::find(); // 返回 ActiveQuery 对象
    $condition = 'hello world';	// 字符串原样保持,可包含 subject:xxx 这种形式
    $condition = ['WILD', 'key1', 'key2' ... ];	// 通过空格将多个查询条件连接
    $condition = ['AND', 'key1', 'key2' ... ]; // 通过 AND 连接,转换为:key1 AND key2
    $condition = ['OR', 'key1', 'key2' ... ]; // 通过 OR 连接
    $condition = ['XOR', 'key1', 'key2' ... ]; // 通过  XOR 连接
    $condition = ['NOT', 'key']; // 排除匹配 key 的结果
    $condition = ['pid' => '123', 'subject' => 'hello']; // 转换为:pid:123 subject:hello
    $condition = ['pid' => ['123', '456']]; // 相当于 IN,转换为:pid:123 OR pid:456
    $condition = ['IN', 'pid', ['123', '456']]; // 转换结果同上
    $condition = ['NOT IN', 'pid', ['123', '456']]; // 转换为:NOT (pid:123 OR pid:456)
    $condition = ['BETWEEN', 'chrono', 14918161631, 15918161631]; // 相当于 XSSearch::addRange(...)
    $condition = ['WEIGHT', 'subject', 'hello', 0.5]; // 相当于额外调用 XSSearch::addWeight('subject', 'hello', 0.5);
    $query->where($condition);
    

    对于 hightman\xunsearch\ActiveQuery 对象,主要支持以下几个方法获取和操作:

  • asArray(): 以数组形式返回数据
  • one(): 返回一行数据
  • all(): 返回全部数据
  • count(): 统计数据匹配数据,是估算的并不是完全准确
  • exists(): 判断查询条件是否存在数据
  • where(): 指定搜索条件
  • orderBy(): 指定排序方式,默认为相关性排序
  • limit(), offfset(): 指定获取数据量和偏移,用于分页检索
  • with(), indexBy ...
  • buildOther(function(\XSSearch $search){}) 可通过此方法定制检索选项
  • 此外,ActiveQuery 还提供了一个名为 beforeSearch 的事件,可在执行搜索前再次对 ActiveQuery::getSearch() 所返回的 XSSearch 对象进行调整。

    如果以 AR 对象获得数据,可通过以下几个方法获取搜索结果元数据,参照 XSDocument 相关用法。

    $model = Demo::findOne(321);
    $model->docid(); //Xapian数据 ID
    $model->rank(); //序号
    $model->percent(); //匹配百分比
    $model->ccount(); //折叠数量,须在 XSSearch::setCollapse() 指定后才有效
    $model->matched(); //获得匹配词汇
    

    ActiveRecord 对象实现了绝大多数据接口,完全可以像使用普通数据库模型一样使用它。如果需要 访问原始的 xunsearch 对象,请通过以下方式获取 Database 对象:

    $db = Demo::getDb();
    $search = $db->getSearch();
    $index = $db->getIndex();
    // 如有必要,还可以获得 scws 分词对象
    $scws = $db->getScws();
    
    使用 xunsearch DebugPanel

    为便于调试,还提供了一个 hightman\xunsearch\DebugPanel 对象,可以集成到 debug 模块中, 可在调试工具条和面板中显示 xunsearch 有关的查询以及耗时情况。

    要想启用这个很容易,只要在主配置文件中加入以下代码:

    // ...
        'bootstrap' => ['debug'],
        'modules' => [
            'debug' => [
                'class' => 'yii\\debug\\Module',
                'panels' => [
                    'xunsearch' => [
                        'class' => 'hightman\\xunsearch\\DebugPanel',
        // ...
    
    其它用法

    TBD. 如关联等,参见其它 AR 用法即可。

    Note: 相关的 AR 索引操作均非实时的,如需实时更新索引,请通过 Database::getIndex()->flushIndex() 刷新。 关于查询日志有关的功能,也建议通过原生的 XSSearchXSIndex 对象来操作。

    Resources