配列をドキュメント フィールドとして格納し、その配列をクエリする方法はありますか?
タグ付けされたアイテムのコレクションがあります。たとえば、タグ 55 と 67 に一致するすべてのアイテムを検索できるようにしたいと考えています。
どうすればこれを達成できますか?
配列をドキュメント フィールドとして格納し、その配列をクエリする方法はありますか?
タグ付けされたアイテムのコレクションがあります。たとえば、タグ 55 と 67 に一致するすべてのアイテムを検索できるようにしたいと考えています。
どうすればこれを達成できますか?
まず、配列内のデータを使用してインデックス ファイルを作成する必要があります。ドキュメントには、新しいインデックスの作成方法が記載されています。
あなたの配列が次のように見えると想像してください
$data = array(
array(
'tag' => '55 67',
'content' => 'Lorem Ipsu 1',
'url' => 'http://foobar.net/content.php?id=1'
),
array(
'tag' => '32 67'
'content' => 'Lorem Ipsu 2',
'url' => 'http://foobar.net/content.php?id=2'
)
);
それはあなたのインデックスを作成するためにそのようなものを与えるでしょう
// Create index
$index = Zend_Search_Lucene::create('/data/my-index');
foreach($data as $row){
$doc = new Zend_Search_Lucene_Document();
// Store document URL to identify it in the search results
$doc->addField(Zend_Search_Lucene_Field::Text('url', $row['url']));
// Store document TAGS
$doc->addField(Zend_Search_Lucene_Field::Text('tag', $row['tag']));
// Index document contents
$doc->addField(Zend_Search_Lucene_Field::UnStored('contents', $row['content']));
// Add document to the index
$index->addDocument($doc);
}
最後に、インデックスファイルをクエリします
$index = Zend_Search_Lucene::open('/data/my_index');
$hits = $index->find('tag:55 AND tag:67');
foreach ($hits as $hit) {
echo $hit->score;
echo $hit->url;
echo $hit->tag;
}
なぜLuceneを使用してそのような作業を行うつもりなのか、よくわかりません.タグに一致する記事のリストが必要な場合は、単純なSQL
クエリで行う方が簡単です.
Zend_Search_Lucene
例としてどのように機能するかを知りたい場合