首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >solr/pysolr与烧瓶炼金

solr/pysolr与烧瓶炼金
EN

Stack Overflow用户
提问于 2014-02-18 05:51:36
回答 1查看 1.3K关注 0票数 2

我正在尝试设置solr用于postgres db,我通过烧瓶sqlalchemy orm使用它。我找到了用于这个目的的pysolr库,但是不清楚如何在sqlalchemy模型中设置挂钩来更新solr索引。有什么例子吗?

pysolr建议通过solr.add手动插入文档,但不清楚如何为不同的数据库表分离索引。

在做了一些研究之后,我提出了以下方法,我想知道这是否是正确的方法:

  1. 在ORM模型中,将after_insert、after_update、after_remove和after_commit挂钩,并在这些事件中插入/更新/删除solr中的对象数据。
  2. 要隔离不同模型的数据,请在solr文档的"id“字段中使用表名作为前缀。solr_id = db_table_name + db_id
  3. 在进行搜索时,获取所有结果,手动筛选与db表匹配的结果,提取ids,根据这些ids查找db并使用这些db结果。

有更好的方法来做这件事吗?谢谢。

EN

回答 1

Stack Overflow用户

发布于 2014-02-18 08:36:58

SQLAlchemySolr是不同的结构。我认为更好的解决方案是实现脚本来同步数据。运行脚本更新新数据可能需要30分钟或一小时。

在模型中绑定insert/update/remove/commit机制并不好。因为如果Solr服务有任何问题,您的网站(关于access数据库)将受到影响。保持差异服务的独立性。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21845395

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档