Exams.php 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. <?php
  2. namespace app\admin\model\teacher;
  3. use think\Model;
  4. use think\Db;
  5. use traits\model\SoftDelete;
  6. class Exams extends Model
  7. {
  8. use SoftDelete;
  9. // 表名
  10. protected $name = 'real_exam';
  11. // 自动写入时间戳字段
  12. protected $autoWriteTimestamp = 'int';
  13. // 定义时间戳字段名
  14. protected $createTime = 'createtime';
  15. protected $updateTime = 'updatetime';
  16. protected $deleteTime = 'deletetime';
  17. // 追加属性
  18. protected $append = [
  19. 'sim_type_text',
  20. 'fault_names',
  21. 'xianxiang_names',
  22. 'yuanyin_names',
  23. 'buwei_names',
  24. 'fangfa_names',
  25. ];
  26. protected static function init()
  27. {
  28. self::beforeUpdate(function ($row) {
  29. if(!empty($row['createtime'])){
  30. $pk = $row->getPk();
  31. $create_time = date('Y-m-d H:i:s',$row['createtime']);
  32. $update_time = date('Y-m-d H:i:s',$row['updatetime']);
  33. $row->getQuery()->where($pk, $row[$pk])->update(['create_time' => $create_time,'update_time'=>$update_time]);
  34. }
  35. });
  36. self::afterInsert(function ($row) {
  37. if(!empty($row['createtime'])){
  38. $pk = $row->getPk();
  39. $create_time = date('Y-m-d H:i:s',$row['createtime']);
  40. $update_time = date('Y-m-d H:i:s',$row['updatetime']);
  41. $row->getQuery()->where($pk, $row[$pk])->update(['create_time' => $create_time,'update_time'=>$update_time]);
  42. }
  43. });
  44. }
  45. public function getSimTypeTextAttr($value, $data)
  46. {
  47. $sim_type_text = '';
  48. if($data['sim_type']=='0001'){
  49. $sim_type_text = 'FZD04B型侦毒器';
  50. }else if ($data['sim_type']=='0002'){
  51. $sim_type_text = 'FZB006型毒剂报警器';
  52. }else if ($data['sim_type']=='0003'){
  53. $sim_type_text = '防化兵用毒剂报警器';
  54. }
  55. return $sim_type_text;
  56. }
  57. public function getFaultNamesAttr($value, $data)
  58. {
  59. $fault_name = '';
  60. $fault_ids = \app\admin\model\teacher\ExamsFault::where(['exam_id'=>$data['exam_id'],'flag'=>1])->column('fault_id');
  61. $fault_name = Db::name('fault')->where('fault_id','in',$fault_ids)->column('name');
  62. return !empty($fault_name)? implode(',',$fault_name):'';
  63. }
  64. //现象
  65. public function getXianxiangNamesAttr($value, $data)
  66. {
  67. $xianxiang_name = '';
  68. return $xianxiang_name;
  69. }
  70. //原因
  71. public function getYuanyinNamesAttr($value, $data)
  72. {
  73. $yuanyin_name = '';
  74. return $yuanyin_name;
  75. }
  76. //部位
  77. public function getBuweiNamesAttr($value, $data)
  78. {
  79. $buwei_name = '';
  80. return $buwei_name;
  81. }
  82. //方法
  83. public function getFangfaNamesAttr($value, $data)
  84. {
  85. $fangfa_name = '';
  86. return $fangfa_name;
  87. }
  88. public function collection() {
  89. return $this->belongsTo('Collection', 'exam_collection_id');
  90. }
  91. public function fault(){
  92. return $this->hasMany('app\admin\model\teacher\ExamsFault','exam_id','exam_id');
  93. }
  94. }