1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 |
- <?php
- /**
- *
- * @author: xaboy<365615158@qq.com>
- * @day: 2017/12/12
- */
- namespace app\models\store;
- use crmeb\basic\BaseModel;
- use think\facade\Cache;
- /**
- * TODO 产品分类Model
- * Class StoreCategory
- * @package app\models\store
- */
- class StoreCategory extends BaseModel
- {
- /**
- * 数据表主键
- * @var string
- */
- protected $pk = 'id';
- /**
- * 模型名称
- * @var string
- */
- protected $name = 'store_category';
- public static function pidByCategory($pid, $field = '*', $limit = 0)
- {
- $model = self::where('pid', $pid)->where('is_show', 1)->order('sort desc,id desc')->field($field);
- if ($limit) $model->limit($limit);
- return $model->select();
- }
- public static function pidBySidList($pid)
- {
- return self::where('pid', $pid)->field('id,cate_name,pid')->select();
- }
- public static function cateIdByPid($cateId)
- {
- return self::where('id', $cateId)->value('pid');
- }
- /*
- * 获取一级和二级分类
- * @return array
- * */
- public static function getProductCategory($expire = 800)
- {
- if (Cache::has('parent_category')) {
- return Cache::get('parent_category');
- } else {
- $parentCategory = self::pidByCategory(0, 'id,cate_name')->toArray();
- foreach ($parentCategory as $k => $category) {
- $category['child'] = self::pidByCategory($category['id'], 'id,cate_name,pic')->toArray();
- $parentCategory[$k] = $category;
- }
- Cache::set('parent_category', $parentCategory, $expire);
- return $parentCategory;
- }
- }
- /**
- * TODO 获取首页展示的二级分类 排序默认降序
- * @param string $field
- * @param int $limit
- * @return false|\PDOStatement|string|\think\Collection
- * @throws \think\db\exception\DataNotFoundException
- * @throws \think\db\exception\ModelNotFoundException
- * @throws \think\exception\DbException
- */
- public static function byIndexList($limit = 4,bool $bool = true, $field = 'id,cate_name,pid,pic')
- {
- if(!$limit && !$bool) return [];
- return self::where('pid', '>', 0)->where('is_show', 1)->field($field)->order('sort DESC')->limit($limit)->select();
- }
- /**
- * 获取子集分类查询条件
- * @return \think\model\relation\HasMany
- */
- public function children()
- {
- return $this->hasMany(self::class, 'pid','id')->where('is_show',1)->order('sort DESC,id DESC');
- }
- }
|