evaluate_goods.model.php 7.6 KB

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