db_tool.cpp 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  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. //#include "../common_tool.h"
  9. namespace db_tool
  10. {
  11. void PushAsync(char* sql)
  12. {
  13. if(!sDBConnPool.PushAsync(sql))
  14. {
  15. log_error( "PushAsync记录到队列中失败\n");
  16. }
  17. }
  18. static std::string type_id_to_str(int32_t type,uint32_t id)
  19. {
  20. char sql[15] = {0};
  21. snprintf(sql, 15,"%03d%010d", type, id);
  22. return std::string(sql);
  23. }
  24. void save_attendance(const std::shared_ptr<card_location_base>& card_ptr)
  25. {
  26. char sql[LENGTH_SQL] = {0};
  27. std::string call("add_att_staff");
  28. if(card_ptr->is_vehicle())//车卡
  29. {
  30. call="add_att_vehicle";
  31. }
  32. auto mine_tool_ptr = card_ptr->get_mine_tool();
  33. auto start = mine_tool_ptr->m_attendance_start_time;
  34. auto end = mine_tool_ptr->m_attendance_start_time;
  35. if(!mine_tool_ptr->is_attendance())//考勤结束时间
  36. {
  37. end = std::chrono::system_clock::now();
  38. }
  39. std::string start_str = tool_time::to_str(start);
  40. std::string end_str = tool_time::to_str(end);
  41. int landmarkid = 0;
  42. int landmarkdirect=0;
  43. double landmarkdist=0;
  44. auto area_hover_ptr = card_ptr->get_area_hover();
  45. if(area_hover_ptr)
  46. {
  47. landmarkid = area_hover_ptr->landmark_id;
  48. landmarkdirect = area_hover_ptr->landmark_dir;
  49. landmarkdist = area_hover_ptr->landmark_dis;
  50. }
  51. sprintf(sql, "CALL %s(%s, %d, '%s', '%s', %d, %d, %.3f);", call.c_str(),
  52. type_id_to_str(card_ptr->m_type,card_ptr->m_id).c_str(),
  53. card_ptr->m_id, start_str.c_str(), end_str.c_str(),
  54. landmarkid, landmarkdirect, landmarkdist);
  55. PushAsync(sql);
  56. }
  57. }