evaluate_goods.model.php 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. <?php
  2. /**
  3. * 商品评价模型
  4. *
  5. */
  6. defined('InShopNC') or exit('Access Invalid!');
  7. class evaluate_goodsModel extends Model {
  8. public function __construct(){
  9. parent::__construct('evaluate_goods');
  10. }
  11. /**
  12. * 查询评价列表
  13. *
  14. * @param array $condition 查询条件
  15. * @param int $page 分页数
  16. * @param string $order 排序
  17. * @param string $field 字段
  18. * @return array
  19. */
  20. public function getEvaluateGoodsList($condition, $page = null, $order = 'geval_id desc', $field = '*') {
  21. $list = $this->field($field)->where($condition)->page($page)->order($order)->select();
  22. return $list;
  23. }
  24. public function getGoodsCommonEvaluateList($common_id, $limit = 0, $page = null, $order = 'geval_id desc')
  25. {
  26. $mod = Model();
  27. $field = 'member.member_avatar,member.member_nickname,member.member_mobile,goods.goods_spec,evaluate_goods.geval_id,evaluate_goods.geval_commonid,evaluate_goods.geval_goodsid,evaluate_goods.geval_goodsname,evaluate_goods.geval_scores,evaluate_goods.geval_content,evaluate_goods.geval_isanonymous,evaluate_goods.geval_addtime,evaluate_goods.geval_frommemberid,evaluate_goods.geval_frommembername,evaluate_goods.geval_explain,evaluate_goods.geval_image';
  28. $on = 'evaluate_goods.geval_frommemberid=member.member_id,goods.goods_id=evaluate_goods.geval_goodsid';
  29. $mod->table('evaluate_goods,member,goods')->field($field);
  30. $mod->join('inner,left')->on($on)->where(array('evaluate_goods.geval_commonid' => $common_id));
  31. $items = $mod->limit($limit)->page($page)->order($order)->select();
  32. return $items;
  33. }
  34. /**
  35. * 根据编号查询商品评价
  36. */
  37. public function getEvaluateGoodsInfoByID($geval_id, $store_id = 0) {
  38. if(intval($geval_id) <= 0) {
  39. return null;
  40. }
  41. $info = $this->where(array('geval_id' => $geval_id))->find();
  42. if($store_id > 0 && intval($info['geval_storeid']) !== $store_id) {
  43. return null;
  44. } else {
  45. return $info;
  46. }
  47. }
  48. /**
  49. * 根据商品编号查询商品评价信息
  50. */
  51. public function getEvaluateGoodsInfoByGoodsID($goods_id) {
  52. $prefix = 'goods_evaluation';
  53. $info = rcache($goods_id, $prefix);
  54. if(empty($info)) {
  55. $info = array();
  56. $count_array = $this->field('count(*) as count,geval_scores')->where(array('geval_goodsid' => $goods_id))->group('geval_scores')->key(geval_scores)->select();
  57. $star1 = intval($count_array['1']['count']);
  58. $star2 = intval($count_array['2']['count']);
  59. $star3 = intval($count_array['3']['count']);
  60. $star4 = intval($count_array['4']['count']);
  61. $star5 = intval($count_array['5']['count']);
  62. $info['good'] = $star4 + $star5;
  63. $info['normal'] = $star2 + $star3;
  64. $info['bad'] = $star1;
  65. $info['all'] = $star1 + $star2 + $star3 + $star4 + $star5;
  66. if(intval($info['all']) > 0) {
  67. $info['good_percent'] = intval($info['good'] / $info['all'] * 100);
  68. $info['normal_percent'] = intval($info['normal'] / $info['all'] * 100);
  69. $info['bad_percent'] = intval($info['bad'] / $info['all'] * 100);
  70. $info['good_star'] = ceil($info['good'] / $info['all'] * 5);
  71. $info['star_average'] = ceil(($star1 + $star2 * 2 + $star3 * 3 + $star4 * 4 + $star5 * 5) / $info['all']);
  72. } else {
  73. $info['good_percent'] = 100;
  74. $info['normal_percent'] = 0;
  75. $info['bad_percent'] = 0;
  76. $info['good_star'] = 5;
  77. $info['star_average'] = 5;
  78. }
  79. //更新商品表好评星级和评论数
  80. $model_goods = Model('goods');
  81. $update = array();
  82. $update['evaluation_good_star'] = $info['star_average'];
  83. $update['evaluation_count'] = $info['all'];
  84. $model_goods->editGoodsById($update, $goods_id);
  85. wcache($goods_id, $info, $prefix);
  86. }
  87. return $info;
  88. }
  89. /**
  90. * 根据抢购编号查询商品评价信息
  91. */
  92. public function getEvaluateGoodsInfoByCommonidID($goods_commonid) {
  93. $prefix = 'goods_common_evaluation';
  94. $info = rcache($goods_commonid, $prefix);
  95. if(empty($info)) {
  96. $info = array();
  97. $info['good_percent'] = 100;
  98. $info['normal_percent'] = 0;
  99. $info['bad_percent'] = 0;
  100. $info['good_star'] = 5;
  101. $info['all'] = 0;
  102. $info['good'] = 0;
  103. $info['normal'] = 0;
  104. $info['bad'] = 0;
  105. $condition = array();
  106. $condition['goods_commonid'] = $goods_commonid;
  107. $goods_list = Model('goods')->getGoodsList($condition, 'goods_id');
  108. if (!empty($goods_list)) {
  109. $goodsid_array = array();
  110. foreach ($goods_list as $value) {
  111. $goodsid_array[] = $value['goods_id'];
  112. }
  113. $good = $this->where(array('geval_goodsid'=>array('in' ,$goodsid_array),'geval_scores' => array('in', '4,5')))->count();
  114. $info['good'] = $good;
  115. $normal = $this->where(array('geval_goodsid'=>array('in' ,$goodsid_array),'geval_scores' => array('in', '2,3')))->count();
  116. $info['normal'] = $normal;
  117. $bad = $this->where(array('geval_goodsid'=>array('in' ,$goodsid_array),'geval_scores' => array('in', '1')))->count();
  118. $info['bad'] = $bad;
  119. $info['all'] = $info['good'] + $info['normal'] + $info['bad'];
  120. if(intval($info['all']) > 0) {
  121. $info['good_percent'] = intval($info['good'] / $info['all'] * 100);
  122. $info['normal_percent'] = intval($info['normal'] / $info['all'] * 100);
  123. $info['bad_percent'] = intval($info['bad'] / $info['all'] * 100);
  124. $info['good_star'] = ceil($info['good'] / $info['all'] * 5);
  125. }
  126. }
  127. wcache($goods_commonid, $info, $prefix, 24*60); // 缓存周期1天。
  128. }
  129. return $info;
  130. }
  131. /**
  132. * 批量添加商品评价
  133. *
  134. * @param array $param
  135. * @param array $goodsid_array 商品id数组,更新缓存使用
  136. * @return boolean
  137. */
  138. public function addEvaluateGoodsArray($param, $goodsid_array) {
  139. $result = $this->insertAll($param);
  140. // 删除商品评价缓存
  141. if ($result && !empty($goodsid_array)) {
  142. foreach ($goodsid_array as $goods_id) {
  143. dcache($goods_id, 'goods_evaluation');
  144. }
  145. }
  146. return $result;
  147. }
  148. /**
  149. * 更新商品评价
  150. *
  151. * 现在此方法只是编辑晒单,不需要更新缓存
  152. * 如果使用此方法修改大星星数量请根据goods_id删除缓存
  153. * 例:dcache($goods_id, 'goods_evaluation');
  154. */
  155. public function editEvaluateGoods($update, $condition) {
  156. return $this->where($condition)->update($update);
  157. }
  158. /**
  159. * 删除商品评价
  160. */
  161. public function delEvaluateGoods($condition) {
  162. return $this->where($condition)->delete();
  163. }
  164. }