1
0

db_tool.cpp 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  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(const char* sql)
  11. {
  12. logn_info(2,"sql:[%s]",sql);
  13. if(!sDBConnPool.PushAsync(sql))
  14. {
  15. logn_error(2,"PushAsync记录到队列中失败");
  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(card_ptr->is_person()?"add_att_staff":"add_att_vehicle");
  29. auto mine_tool_ptr = card_ptr->get_mine_tool();
  30. auto start = mine_tool_ptr->m_attendance_start_time;
  31. auto end = mine_tool_ptr->m_attendance_start_time;
  32. if(!mine_tool_ptr->m_is_attendance)//考勤结束时间
  33. {
  34. end = std::chrono::system_clock::now();
  35. }
  36. std::string start_str = tool_time::to_str(start);
  37. std::string end_str = tool_time::to_str(end);
  38. auto map_area_info = card_ptr->get_area_tool()->m_area_info;
  39. int landmarkid=0,landmarkdirect=0;
  40. double landmarkdist=0;
  41. if(!map_area_info.empty())
  42. {
  43. auto lm = map_area_info.begin()->second;
  44. landmarkid = std::get<1>(lm);
  45. landmarkdirect=std::get<2>(lm);
  46. landmarkdist=std::get<3>(lm);
  47. }
  48. sprintf(sql, "CALL %s(%s, %d, '%s', '%s', %d, %d, %.3lf);", call.c_str(),
  49. type_id_to_str(card_ptr->m_type,card_ptr->m_id).c_str(),
  50. card_ptr->m_cid, start_str.c_str(), end_str.c_str(),
  51. landmarkid, landmarkdirect, landmarkdist);
  52. log_info("attendance():%s",sql);
  53. PushAsync(sql);
  54. }
  55. }