当前位置:  开发笔记 > 数据库 > 正文

在CouchDB上实现用户评级/收藏夹

如何解决《在CouchDB上实现用户评级/收藏夹》经验,为你挑选了1个好方法。

我正在考虑将CouchDB用于即将推出的网站,但就如何为网站实施用户评级系统而言,我有点困惑.基本上,每个内容项可以由给定用户评级.这样做的方式在CouchDB模型中最有意义?我认为DRYest和最合乎逻辑的方式是拥有3种不同的文档类型,内容,用户和看起来像这样的user_rating doc.

{
  user_id: "USERID"
  content_id: "CONTENTID"
  rating: 6
}

然后,我创建一个视图,其中地图是由内容doc ID键入的所有内容文档和user_rating文档的集合,其中reduce计算了评级的平均值,并返回由内容doc id键入的内容文档.

这是最好的方法吗?我还没有找到关于CouchDB最佳实践资源的方法,所以我很不确定所有这些东西.

我的结论:下面接受的答案,即我将要实现的内容确实有效,但要注意,文档需要由内容doc id键入,这使得基于其他文档属性的高级查询很麻烦.我将在这个应用程序中回到SQL以满足我的需求.



1> 小智..:

听起来你有一个合理的想法.CouchDB是如此新颖,我认为最佳实践需要一段时间才能摆脱.

像这样的map/reduce对可能是一个合理的起点.

地图:

function(doc) {
   if(doc.type='rating' && doc.content_id) {
     emit(doc.content_id, doc.rating);
   }
}

降低:

function(keys, values) {
   return sum(values)/values.length
}

注意:该map功能需要在Rating模型中添加适当的类型:

{
  type: 'rating',
  user_id: "USERID",
  content_id: "CONTENTID",
  rating: 6
}


两件事:你本身不需要评级类型,只需要(doc.user_id && doc.content_id && doc.rating)发出(doc.content_id,doc.rating)请记住,为了完成这项工作,你需要指定访问视图时group = true.
推荐阅读
喜生-Da
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有