题
我正在寻找有关在不同 ORM 中处理搜索的信息。
目前我正在用 PHP 重新开发一些旧应用程序,要求之一是:使所有或几乎所有内容都可搜索,因此用户只需输入“punkrock live”,应用程序就会找到以这种方式标记的视频剪辑、音乐曲目、评论、即将举行的活动甚至用户评论。
在所有内容均可搜索的环境中,ORM 需要通过两种方式支持此功能:
- 在 ORM 的“O”端提供一些索引 API
- 提供“R”端批量数据库检索的方法
理想的解决方案是根据搜索到的字符串返回现成的对象。您知道有什么好的端到端解决方案可以完成这项工作,但不一定是 PHP 吗?如果您处理过类似的问题,那么很高兴听听您的经历。超过的东西 使用Lucene 或者 语义网就是出路 oneliners,不过;-)*
其他提示
在 Propel 1.3 schema.xml 文件中,您可以指定您希望所有模型扩展您创建的“BaseModel”类。
在该 BaseModel 中,您将重新定义 save() 方法,如下所示:
public function save(PropelPDO $con = null)
{
if($this->getIsSearchable())
{
// update your search index here. Lucene, Sphinx, or otherwise
}
return parent::save($conn);
}
这负责保持所有内容的索引。至于搜索,我建议使用一些方法创建一个 Search 类。
class Search
{
protected $_searchableTypes = array('music','video','blog');
public method findAll($search_term)
{
$results = array();
foreach($this->_searchableTypes as $type)
{
$results[] = $this->findType($type, $search_term);
}
return $results;
}
}
不隶属于 StackOverflow