52 lines
1.3 KiB
PHP
52 lines
1.3 KiB
PHP
<?php
|
|
|
|
|
|
namespace addons\xilufitness\model;
|
|
|
|
|
|
use addons\xilufitness\traits\BaseModel;
|
|
use think\Db;
|
|
use think\Model;
|
|
|
|
class OrderComment extends Model
|
|
{
|
|
use BaseModel;
|
|
|
|
// 表名
|
|
protected $name = 'xilufitness_user_comment';
|
|
|
|
// 自动写入时间戳字段
|
|
protected $autoWriteTimestamp = 'integer';
|
|
|
|
// 定义时间戳字段名
|
|
protected $createTime = 'createtime';
|
|
protected $updateTime = 'updatetime';
|
|
|
|
// 追加属性
|
|
protected $append = [
|
|
'createtime_txt'
|
|
];
|
|
|
|
public function getCreatetimeTxtAttr($value,$data){
|
|
$value = $value ? $value : ($data['createtime'] ?? time() );
|
|
return date('Y.m.d',$value);
|
|
}
|
|
|
|
protected static function init()
|
|
{
|
|
self::afterInsert(function ($row){
|
|
$count = Db::name('xilufitness_user_comment')->where(['shop_id' => $row['shop_id']])->count('*');
|
|
$sum_star = Db::name('xilufitness_user_comment')->where(['shop_id' => $row['shop_id']])->sum('star');
|
|
$avage_star = $count > 0 ? $sum_star/$count : 0;
|
|
Db::name('xilufitness_shop')->where(['id' => $row['shop_id'] ?? 0])->update(['star' => $avage_star]);
|
|
});
|
|
}
|
|
|
|
/**
|
|
* 关联用户
|
|
*/
|
|
public function user(){
|
|
return $this->belongsTo(User::class,'user_id','id',[],'LEFT')->setEagerlyType(0);
|
|
}
|
|
|
|
} |