Evaluategoods.php 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. <?php
  2. namespace app\common\model;
  3. use think\facade\Db;
  4. /**
  5. * ============================================================================
  6. * DSMall多用户商城
  7. * ============================================================================
  8. * 版权所有 2014-2028 长沙德尚网络科技有限公司,并保留所有权利。
  9. * 网站地址: http://www.csdeshang.com
  10. * ----------------------------------------------------------------------------
  11. * 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用 .
  12. * 不允许对程序代码以任何形式任何目的的再发布。
  13. * ============================================================================
  14. * 数据层模型
  15. */
  16. class Evaluategoods extends BaseModel {
  17. public $page_info;
  18. /**
  19. * 查询评价列表
  20. * @access public
  21. * @author csdeshang
  22. * @param array $condition 查询条件
  23. * @param int $pagesize 分页数
  24. * @param string $order 排序
  25. * @param string $field 字段
  26. * @return array
  27. */
  28. public function getEvaluategoodsList($condition, $pagesize = null, $order = 'geval_id desc', $field = '*') {
  29. if ($pagesize) {
  30. $list = Db::name('evaluategoods')->field($field)->where($condition)->order($order)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false);
  31. $this->page_info = $list;
  32. return $list->items();
  33. } else {
  34. $list = Db::name('evaluategoods')->field($field)->where($condition)->order($order)->select()->toArray();
  35. return $list;
  36. }
  37. }
  38. /**
  39. * 根据编号查询商品评价
  40. * @access public
  41. * @author csdeshang
  42. * @param int $geval_id 编号
  43. * @param int $store_id 店铺ID
  44. * @return type
  45. */
  46. public function getEvaluategoodsInfoByID($geval_id, $store_id = 0) {
  47. if (intval($geval_id) <= 0) {
  48. return null;
  49. }
  50. $info = Db::name('evaluategoods')->where(array('geval_id' => $geval_id))->find();
  51. if ($store_id > 0 && intval($info['geval_storeid']) !== $store_id) {
  52. return null;
  53. } else {
  54. return $info;
  55. }
  56. }
  57. /**
  58. * 根据商品编号查询商品评价信息
  59. * @access public
  60. * @author csdeshang
  61. * @param int $goods_id 商品ID
  62. * @return array
  63. */
  64. public function getEvaluategoodsInfoByGoodsID($goods_id) {
  65. $prefix = 'goods_evaluation';
  66. $info = rcache($goods_id, $prefix);
  67. if (empty($info)) {
  68. $info = array();
  69. $count_array = Db::name('evaluategoods')->field('count(*) as count,geval_scores')->where(array('geval_goodsid' => $goods_id))->group('geval_scores')->select()->toArray();
  70. $count_array = ds_change_arraykey($count_array, 'geval_scores');
  71. $star1 = isset($count_array['1']['count']) ? intval($count_array['1']['count']) : 0;
  72. $star2 = isset($count_array['2']['count']) ? intval($count_array['2']['count']) : 0;
  73. $star3 = isset($count_array['3']['count']) ? intval($count_array['3']['count']) : 0;
  74. $star4 = isset($count_array['4']['count']) ? intval($count_array['4']['count']) : 0;
  75. $star5 = isset($count_array['5']['count']) ? intval($count_array['5']['count']) : 0;
  76. $info['good'] = $star4 + $star5;
  77. $info['normal'] = $star2 + $star3;
  78. $info['bad'] = $star1;
  79. $info['all'] = $star1 + $star2 + $star3 + $star4 + $star5;
  80. if (intval($info['all']) > 0) {
  81. $info['good_percent'] = intval($info['good'] / $info['all'] * 100);
  82. $info['normal_percent'] = intval($info['normal'] / $info['all'] * 100);
  83. $info['bad_percent'] = intval($info['bad'] / $info['all'] * 100);
  84. $info['good_star'] = ceil($info['good'] / $info['all'] * 5);
  85. $info['star_average'] = ceil(($star1 + $star2 * 2 + $star3 * 3 + $star4 * 4 + $star5 * 5) / $info['all']);
  86. } else {
  87. $info['good_percent'] = 100;
  88. $info['normal_percent'] = 0;
  89. $info['bad_percent'] = 0;
  90. $info['good_star'] = 5;
  91. $info['star_average'] = 5;
  92. }
  93. //更新商品表好评星级和评论数
  94. $goods_model = model('goods');
  95. $update = array();
  96. $update['evaluation_good_star'] = $info['star_average'];
  97. $update['evaluation_count'] = $info['all'];
  98. $goods_model->editGoodsById($update, $goods_id);
  99. wcache($goods_id, $info, $prefix);
  100. }
  101. return $info;
  102. }
  103. /**
  104. * 根据抢购编号查询商品评价信息
  105. * @access public
  106. * @author csdeshang
  107. * @param int $goods_commonid 抢购编号
  108. * @return array
  109. */
  110. public function getEvaluategoodsInfoByCommonidID($goods_commonid) {
  111. $prefix = 'goods_common_evaluation';
  112. $info = rcache($goods_commonid, $prefix);
  113. if (empty($info)) {
  114. $info = array();
  115. $info['good_percent'] = 100;
  116. $info['normal_percent'] = 0;
  117. $info['bad_percent'] = 0;
  118. $info['good_star'] = 5;
  119. $info['all'] = 0;
  120. $info['good'] = 0;
  121. $info['normal'] = 0;
  122. $info['bad'] = 0;
  123. $condition = array();
  124. $condition[] = array('goods_commonid','=',$goods_commonid);
  125. $goods_list = model('goods')->getGoodsList($condition, 'goods_id');
  126. if (!empty($goods_list)) {
  127. $goodsid_array = array();
  128. foreach ($goods_list as $value) {
  129. $goodsid_array[] = $value['goods_id'];
  130. }
  131. $good = Db::name('evaluategoods')->where('geval_goodsid','in', $goodsid_array)->where('geval_scores','in', '4,5')->count();
  132. $info['good'] = $good;
  133. $normal = Db::name('evaluategoods')->where('geval_goodsid','in', $goodsid_array)->where('geval_scores','in', '2,3')->count();
  134. $info['normal'] = $normal;
  135. $bad = Db::name('evaluategoods')->where('geval_goodsid','in', $goodsid_array)->where('geval_scores','in', '1')->count();
  136. $info['bad'] = $bad;
  137. $info['all'] = $info['good'] + $info['normal'] + $info['bad'];
  138. if (intval($info['all']) > 0) {
  139. $info['good_percent'] = intval($info['good'] / $info['all'] * 100);
  140. $info['normal_percent'] = intval($info['normal'] / $info['all'] * 100);
  141. $info['bad_percent'] = intval($info['bad'] / $info['all'] * 100);
  142. $info['good_star'] = ceil($info['good'] / $info['all'] * 5);
  143. }
  144. }
  145. wcache($goods_commonid, $info, $prefix, 24 * 60); // 缓存周期1天。
  146. }
  147. return $info;
  148. }
  149. /**
  150. * 批量添加商品评价
  151. * @access public
  152. * @author csdeshang
  153. * @param array $datas 参数内容
  154. * @param array $goodsid_array 商品id数组,更新缓存使用
  155. * @return boolean
  156. */
  157. public function addEvaluategoodsArray($datas, $goodsid_array) {
  158. $result = Db::name('evaluategoods')->insertAll($datas);
  159. // 删除商品评价缓存
  160. if ($result && !empty($goodsid_array)) {
  161. foreach ($goodsid_array as $goods_id) {
  162. dcache($goods_id, 'goods_evaluation');
  163. }
  164. }
  165. return $result;
  166. }
  167. /**
  168. * 更新商品评价
  169. *
  170. * 现在此方法只是编辑晒单,不需要更新缓存
  171. * 如果使用此方法修改大星星数量请根据goods_id删除缓存
  172. * 例:dcache($goods_id, 'goods_evaluation');
  173. * @access public
  174. * @author csdeshang
  175. * @param array $update 更新数据
  176. * @param array $condition 条件
  177. * @return bool
  178. */
  179. public function editEvaluategoods($update, $condition) {
  180. $goodsid_array = Db::name('evaluategoods')->where($condition)->column('geval_goodsid');
  181. foreach ($goodsid_array as $goods_id) {
  182. dcache($goods_id, 'goods_evaluation');
  183. }
  184. return Db::name('evaluategoods')->where($condition)->update($update);
  185. }
  186. /**
  187. * 删除商品评价
  188. * @access public
  189. * @author csdeshang
  190. * @param type $condition 条件
  191. * @return bool
  192. */
  193. public function delEvaluategoods($condition) {
  194. $goodsid_array = Db::name('evaluategoods')->where($condition)->column('geval_goodsid');
  195. foreach ($goodsid_array as $goods_id) {
  196. dcache($goods_id, 'goods_evaluation');
  197. }
  198. return Db::name('evaluategoods')->where($condition)->delete();
  199. }
  200. }
  201. ?>