db_tool.cpp 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. #include "log.h"
  2. #include "db_api/CDBSingletonDefine.h"
  3. #include "card_base.h"
  4. #include "mine.h"
  5. #include "area.h"
  6. #include "tool_time.h"
  7. #include "db_tool.h"
  8. namespace db_tool
  9. {
  10. void PushAsync(char* sql)
  11. {
  12. if(!sDBConnPool.PushAsync(sql))
  13. {
  14. log_error( "PushAsync记录到队列中失败\n");
  15. }
  16. }
  17. void save_attendance(const std::shared_ptr<card_location_base>& card_ptr)
  18. {
  19. char sql[LENGTH_SQL] = {0};
  20. std::string call("add_att_staff");
  21. if(card_ptr->is_vehicle())//车卡
  22. {
  23. call="add_att_vehicle";
  24. }
  25. auto mine_tool_ptr = card_ptr->get_mine_tool();
  26. auto start = mine_tool_ptr->m_attendance_start_time;
  27. auto end = mine_tool_ptr->m_attendance_start_time;
  28. if(!mine_tool_ptr->is_attendance())//考勤结束时间
  29. {
  30. end = std::chrono::system_clock::now();
  31. }
  32. std::string start_str = tool_time::to_str(start);
  33. std::string end_str = tool_time::to_str(end);
  34. int landmarkid = 0;
  35. int landmarkdirect=0;
  36. double landmarkdist=0;
  37. auto area_hover_ptr = card_ptr->get_area_hover();
  38. if(area_hover_ptr)
  39. {
  40. landmarkid = area_hover_ptr->landmark_id;
  41. landmarkdirect = area_hover_ptr->landmark_dir;
  42. landmarkdist = area_hover_ptr->landmark_dis;
  43. }
  44. sprintf(sql, "CALL %s(%s, %d, '%s', '%s', %d, %d, %.3f);", call.c_str(),
  45. card_ptr->id64_str().c_str(),
  46. card_ptr->m_id, start_str.c_str(), end_str.c_str(),
  47. landmarkid, landmarkdirect, landmarkdist);
  48. PushAsync(sql);
  49. }
  50. }