Exclusive.php 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. <?php
  2. namespace app\admin\model;
  3. use think\Model;
  4. class Exclusive extends Model
  5. {
  6. // 表名
  7. protected $table = 'exclusive';
  8. // 自动写入时间戳字段
  9. protected $autoWriteTimestamp = 'int';
  10. // 定义时间戳字段名
  11. protected $createTime = 'createtime';
  12. protected $updateTime = 'updatetime';
  13. // 追加属性
  14. protected $append = [
  15. 'endtime_text',
  16. 'createtime_text'
  17. ];
  18. public function getEndtimeTextAttr($value, $data)
  19. {
  20. $value = $value ? $value : $data['endtime'];
  21. return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value;
  22. }
  23. public function getCreatetimeTextAttr($value, $data)
  24. {
  25. $value = $value ? $value : $data['createtime'];
  26. return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value;
  27. }
  28. protected function setEndtimeAttr($value)
  29. {
  30. return $value && !is_numeric($value) ? strtotime($value) : $value;
  31. }
  32. protected function setCreatetimeAttr($value)
  33. {
  34. return $value && !is_numeric($value) ? strtotime($value) : $value;
  35. }
  36. public function getAllBindChannelIds(){
  37. $sql = "SELECT DISTINCT ec.cid FROM `exclusive_channel` AS ec INNER JOIN `exclusive` AS e ON ec.eid=e.id WHERE e.endtime>".time()." AND e.status=1";
  38. $rs = $this->query($sql);
  39. if(!empty($rs)){
  40. $result = array_column($rs,'cid');
  41. }else{
  42. $result = [];
  43. }
  44. return $result;
  45. }
  46. }