123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- <?php namespace App\Models\Product;
- use App\Models\Traits\MultipUpdate;
- use Illuminate\Database\Eloquent\Factories\HasFactory;
- use Illuminate\Database\Eloquent\Model;
- /**
- * 产品SKU
- *
- */
- class Skus extends Model
- {
- use HasFactory,MultipUpdate;
- // 与模型关联的表名
- protected $table = 'product_skus';
- // 是否主动维护时间戳
- public $timestamps = false;
- // 定义时间戳字段名
- // const CREATED_AT = 'insert_time';
- // const UPDATED_AT = 'update_time';
- /**
- * 添加数据
- *
- */
- public function add($data)
- {
- // 时间
- $data['insert_time'] = time();
- $data['update_time'] = time();
- // 写入数据表
- $id = $this->query()->insertGetId($data);
- // 如果操作失败
- if( !$id ) return $id;
- // 返回结果
- return $id;
- }
- /**
- * 添加数据
- *
- */
- public function edit($id,$data)
- {
- // 更新时间
- $data['update_time'] = time();
- // 写入数据表
- $result = $this->query()->where([['id','=',$id]])->update($data);
- // 如果操作失败
- if( !$result ) return 0;
- // 返回结果
- return $id;
- }
- /**
- * 添加数据
- *
- */
- public function getIdByAttrIds($attrIds,$productId)
- {
- // 写入数据表
- $id = $this->query()->where([['attr_ids','=',$attrIds],['product_id','=',$productId]])->value('id');
- // 如果操作失败
- if( !$id ) return 0;
- // 返回结果
- return $id;
- }
- /**
- * 添加数据
- *
- */
- public function getListByIds($skuIds)
- {
- // 写入数据表
- $data = $this->query()->whereIn('id',$skuIds)->where([['status','=',0]])->get(['id as sku_id','product_id','attr_names as sku_attr_names','quota','min_quota','price','market_price','stock','status'])->toArray();
- // 列表
- $list = [];
- // 循环处理
- foreach ($data as $value) {
- // 重组数据
- $list[$value['sku_id']]= $value;
- }
- // 返回结果
- return $list;
- }
- /**
- * 添加数据
- *
- */
- public function getListByProductId($productId)
- {
- // 写入数据表
- $list = $this->query()->where([['product_id','=',$productId]])->get(['id','attr_ids','attr_names','min_quota','quota','sku_thumb','price','market_price','stock','status'])->toArray();
- // 返回结果
- return $list;
- }
- }
|