Student.php
4.3 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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
<?php
namespace app\admin\model;
use think\Db;
use think\Model;
use traits\model\SoftDelete;
class Student extends Model
{
use SoftDelete;
// 表名
protected $name = 'student';
// 自动写入时间戳字段
protected $autoWriteTimestamp = 'int';
// 定义时间戳字段名
protected $createTime = 'createtime';
protected $updateTime = 'updatetime';
protected $deleteTime = false;
// 追加属性
protected $append = [
'level_text',
'starttime_text',
'endtime_text',
'vip_level_text',
'vip_endtime_text'
];
public function getLevelList()
{
return ['1' => __('Level 1'), '2' => __('Level 2')];
}
public function getVipLevelList()
{
return ['0' => __('Vip_level 0'), '1' => __('Vip_level 1'), '2' => __('Vip_level 2')];
}
public function getLevelTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['level']) ? $data['level'] : '');
$list = $this->getLevelList();
return isset($list[$value]) ? $list[$value] : '';
}
public function getStarttimeTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['starttime']) ? $data['starttime'] : '');
return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value;
}
public function getEndtimeTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['endtime']) ? $data['endtime'] : '');
return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value;
}
public function getVipLevelTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['vip_level']) ? $data['vip_level'] : '');
$list = $this->getVipLevelList();
return isset($list[$value]) ? $list[$value] : '';
}
public function getVipEndtimeTextAttr($value, $data)
{
$value = $value ? $value : (isset($data['vip_endtime']) ? $data['vip_endtime'] : '');
return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value;
}
protected function setStarttimeAttr($value)
{
return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value);
}
protected function setEndtimeAttr($value)
{
return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value);
}
protected function setVipEndtimeAttr($value)
{
return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value);
}
public function school()
{
return $this->belongsTo('School', 'school_id', 'id', [], 'LEFT')->setEagerlyType(0);
}
public function subject()
{
return $this->belongsTo('Subject', 'subject_ids', 'id', [], 'LEFT')->setEagerlyType(0);
}
public function up()
{
return $this->belongsTo('Up', 'up_id', 'id', [], 'LEFT')->setEagerlyType(0);
}
public function college()
{
return $this->belongsTo('College', 'college_id', 'id', [], 'LEFT')->setEagerlyType(0);
}
public function graduated()
{
return $this->belongsTo('Graduated', 'graduated_id', 'id', [], 'LEFT')->setEagerlyType(0);
}
public function delAll($userId){
Db::startTrans();
try {
Db::name('article')->where('user_id',$userId)->delete();
Db::name('like_article')->where('user_id',$userId)->delete();
Db::name('like_student')->whereOr(['usera_id'=>$userId,'userb_id'=>$userId])->delete();
Db::name('like_university')->where('user_id',$userId)->delete();
Db::name('look_article')->where('user_id',$userId)->delete();
Db::name('withdraw_log')->where('user_id',$userId)->delete();
Db::name('user_token')->where('user_id',$userId)->delete();
Db::name('user_money_log')->where('user_id',$userId)->delete();
Db::name('order')->where('user_id',$userId)->delete();
Db::name('mes')->whereOr(['usera_id'=>$userId,'userb_id'=>$userId])->delete();
Db::commit();
} catch (PDOException $e) {
Db::rollback();
$this->error($e->getMessage());
} catch (Exception $e) {
Db::rollback();
$this->error($e->getMessage());
}
}
}