ShinfoModel.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. <?php
  2. namespace app\common\model;
  3. use think\Model;
  4. /**
  5. * 手环信息
  6. *
  7. * @author wj
  8. * @date 2023-08-19
  9. */
  10. class ShinfoModel extends Model
  11. {
  12. protected $table = "t_shouhuan_info";
  13. public function insertData($data)
  14. {
  15. $data = $this->formatData($data);
  16. if (empty($data)) {
  17. return false;
  18. }
  19. $id = $this->insertGetId($data);
  20. return $id ? $id : false;
  21. }
  22. public function getList($where = [], $field = "*", $page = 1, $size = 10, $order = "id desc", $group = "", $row = false)
  23. {
  24. $sqlObj = $this->where($where);
  25. if ("count" != $field) {
  26. if (empty($size)) {
  27. $sqlObj = $sqlObj->field($field)->order($order)->group($group);
  28. } else {
  29. $sqlObj = $sqlObj->field($field)->order($order)->group($group)->page($page, $size);
  30. }
  31. if ($row) {
  32. $data = $sqlObj->find();
  33. } else {
  34. $data = $sqlObj->select();
  35. }
  36. } else {
  37. $data = $sqlObj->count();
  38. }
  39. return $data;
  40. }
  41. /**
  42. * 根据id删除信息
  43. *
  44. * @param [type] $id
  45. * @return void
  46. * @author wj
  47. * @date 2023-08-14
  48. */
  49. public function deleteinfobyid($id)
  50. {
  51. $where = ['id' => $id];
  52. $row = $this->where($where)->delete();
  53. return empty($row) ? false : $row;
  54. }
  55. public function updateinfo($where, $updateData)
  56. {
  57. $updateData = $this->formatData($updateData);
  58. $row = $this->where($where)->update($updateData);
  59. return empty($row) ? false : $row;
  60. }
  61. private function formatData($data)
  62. {
  63. $useData = [];
  64. $fields = $this->getTableFields();
  65. foreach ($data as $key => $value) {
  66. if (in_array($key, $fields)) {
  67. $useData[$key] = $value;
  68. }
  69. }
  70. return $useData;
  71. }
  72. public function getInfo($where, $field = "*", $row = true)
  73. {
  74. $info = $this->field($field)->where($where);
  75. if ($row) {
  76. $info = $info->find();
  77. } else {
  78. $info = $info->select();
  79. }
  80. return empty($info) ? false : $info;
  81. }
  82. /**
  83. * 格式化信息
  84. *
  85. * @return void
  86. * @author wj
  87. * @date 2023-08-15
  88. */
  89. public function formatinfo($data)
  90. {
  91. //血压
  92. if (isset($data['blood_height_pressure']) || isset($data['blood_low_pressure'])) {
  93. $data['blood_update_time'] = date('Y-m-d H:i:s');
  94. }
  95. //心率
  96. if (isset($data['heart_rate'])) {
  97. $data['heart_update_time'] = date('Y-m-d H:i:s');
  98. }
  99. //血养
  100. if (isset($data['oxygen'])) {
  101. $data['oxygen_update_time'] = date('Y-m-d H:i:s');
  102. }
  103. //体温
  104. if (isset($data['temp'])) {
  105. $data['temp_update_time'] = date('Y-m-d H:i:s');
  106. }
  107. //gps
  108. if (isset($data['gps_long']) || isset($data['gps_lat']) || isset($data['use_gps_long']) || isset($data['use_gps_lat'])) {
  109. $data['gps_update_time'] = date('Y-m-d H:i:s');
  110. }
  111. //电量
  112. if (isset($data['electric_quantity'])) {
  113. $data['electric_quantity_update_time'] = date('Y-m-d H:i:s');
  114. }
  115. //步数
  116. if (isset($data['step_number'])) {
  117. $data['step_number_update_time'] = date('Y-m-d H:i:s');
  118. }
  119. //翻滚数
  120. if (isset($data['roll_number'])) {
  121. $data['roll_number_update_time'] = date('Y-m-d H:i:s');
  122. }
  123. //终端状态
  124. if (isset($data['terminal_status'])) {
  125. $data['terminal_status_update_time'] = date('Y-m-d H:i:s');
  126. }
  127. return $data;
  128. }
  129. /**
  130. * 获取下线时间验证列表
  131. *
  132. * @return void
  133. * @author wj
  134. * @date 2023-08-21
  135. */
  136. public function getcheckupdatetimelist()
  137. {
  138. //判断时长1分钟
  139. $time = date('Y-m-d H:i:s');
  140. $maxtime = 1; //1分钟
  141. // $sql = "select * from " . $this->table . " where facility_id in(
  142. // select distinct facility_id from t_shouhuan_receive_redocde
  143. // where TIMESTAMPDIFF(MINUTE, createtime, '" . $time . "')>" . $maxtime . " ) and online_statis=1";
  144. $sql = "select * from " . $this->table . " where TIMESTAMPDIFF(MINUTE, receive_time, '" . $time . "')>" . $maxtime . " and online_statis=1";
  145. $list = $this->query($sql);
  146. return $list;
  147. }
  148. /**
  149. * 设置上线信息
  150. *
  151. * @param [type] $ids
  152. * @return void
  153. * @author wj
  154. * @date 2023-08-21
  155. */
  156. public function setonlineinfobyid($id)
  157. {
  158. $updateData = [
  159. 'online_statis' => 1,
  160. 'onlinetime' => date('Y-m-d H:i:s'),
  161. ];
  162. $where = ['id' => $id];
  163. $row = $this->where($where)->update($updateData);
  164. }
  165. /**
  166. * 设置下线信息
  167. *
  168. * @param [type] $ids
  169. * @return void
  170. * @author wj
  171. * @date 2023-08-21
  172. */
  173. public function setofflineinfobyids($ids)
  174. {
  175. $updateData = [
  176. 'online_statis' => 0,
  177. 'offlinetime' => date('Y-m-d H:i:s'),
  178. ];
  179. $where = ['id' => ['in', $ids]];
  180. $row = $this->where($where)->update($updateData);
  181. }
  182. }