UserScoreLog.php
2.1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
<?php
namespace app\api\model;
use app\common\model\MoneyLog;
use app\common\model\ScoreLog;
use think\Db;
use think\Model;
class UserScoreLog extends Model
{
// 自动写入时间戳字段
protected $autoWriteTimestamp = 'int';
// 定义时间戳字段名
protected $createTime = 'createtime';
protected $updateTime = false;
protected $append = [
'type_text'
];
public function getCreatetimeAttr($value)
{
return date('Y-m-d H:i', $value);
}
public function getTypeList()
{
return ['1' => '购物返积分', '2' => '积分商城兑换'];
}
public function getTypeTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['type']) ? $data['type'] : '');
$list = $this->getTypeList();
return isset($list[$value]) ? $list[$value] : '';
}
public function selectPageData($where, $page, $limit,$betweenTime)
{
$total = $this
->where($where)
->whereTime('createtime','between',$betweenTime)
->count();
$list = $this
->where($where)
->whereTime('createtime','between',$betweenTime)
->field('score,after,type,createtime')
->page($page, $limit)
->select();
return ['total' => $total, 'list' => $list];
}
public function setDecScore($userId,$score){
Db::startTrans();
$oldscore = Db::name('user')->where('id', $userId)->value('score');
try {
$res1 = Db::name('user')->where('id',$userId)->setDec('score',$score);
$data = [
'user_id' => $userId,
'type' => 2,
'score' => $score,
'before' => $oldscore,
'after' => $oldscore-$score,
'createtime' => time(),
];
$res2 = $this->save($data);
if ($res1 && $res2 ) {
Db::commit();
return true;
}else{
return false;
}
} catch (Exception $e) {
Db::rollback();
return false;
}
}
}