db_tool.cpp 1.8 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. //#include "../common_tool.h"
  9. namespace db_tool
  10. {
  11. void PushAsync(const 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. const std::shared_ptr<area_hover>& area_hover_ptr)
  26. {
  27. char sql[LENGTH_SQL] = {0};
  28. std::string call("add_att_staff");
  29. if(card_ptr->is_vehicle())//车卡
  30. {
  31. call="add_att_vehicle";
  32. }
  33. auto mine_tool_ptr = card_ptr->get_mine_tool();
  34. auto start = mine_tool_ptr->m_attendance_start_time;
  35. auto end = mine_tool_ptr->m_attendance_start_time;
  36. if(!mine_tool_ptr->m_is_attendance)//考勤结束时间
  37. {
  38. end = std::chrono::system_clock::now();
  39. }
  40. std::string start_str = tool_time::to_str(start);
  41. std::string end_str = tool_time::to_str(end);
  42. int landmarkid = area_hover_ptr->landmark_id;
  43. int landmarkdirect=area_hover_ptr->landmark_dir;
  44. double landmarkdist=area_hover_ptr->landmark_dis;
  45. sprintf(sql, "CALL %s(%s, %d, '%s', '%s', %d, %d, %.3f);", call.c_str(),
  46. type_id_to_str(card_ptr->m_type,card_ptr->m_id).c_str(),
  47. card_ptr->m_id, start_str.c_str(), end_str.c_str(),
  48. landmarkid, landmarkdirect, landmarkdist);
  49. PushAsync(sql);
  50. }
  51. }