1
0

db_card.cpp 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. #include <memory>
  2. #include <unordered_map>
  3. #include "log.h"
  4. #include "config_file.h"
  5. #include "db_api/CDBResultSet.h"
  6. #include "db_api/CDBSingletonDefine.h"
  7. #include "../card_base.h"
  8. #include "../card_person.h"
  9. #include "../common.h"
  10. #include "../common_tool.h"
  11. extern config_file config;
  12. namespace db_card
  13. {
  14. std::unordered_map<uint64_t,std::shared_ptr<card_location_base>> load_car(const std::string & lszId64)
  15. {
  16. std::string sql = "SELECT ve.vehicle_id, ve.card_id, c.card_type_id, \
  17. ve.dept_id, ve.group_id, v.vehicle_type_id, vt.vehicle_level_id, \
  18. vt.is_railroad AS vt_is_railroad,ve.need_display ,ve.power_alarm,\
  19. vt.vehicle_category_id,v.bigger_car_flag,vc.over_speed \
  20. FROM dat_vehicle_extend ve \
  21. LEFT JOIN dat_vehicle v ON ve.vehicle_id = v.vehicle_id \
  22. LEFT JOIN dat_card c ON ve.card_id = c.card_id \
  23. LEFT JOIN dat_dept d ON ve.dept_id = d.dept_id \
  24. LEFT JOIN dat_group g ON ve.group_id = g.group_id \
  25. LEFT JOIN dat_vehicle_type vt ON v.vehicle_type_id = vt.vehicle_type_id \
  26. LEFT JOIN dat_vehicle_category vc ON vc.vehicle_category_id = vt.vehicle_category_id \
  27. WHERE c.state_id = 0";
  28. std::unordered_map<uint64_t,std::shared_ptr<card_location_base>> map;
  29. if("" == lszId64)
  30. {
  31. sql.append(";");
  32. }
  33. else
  34. {
  35. sql.append(" AND ve.card_id ='");
  36. sql.append(lszId64);
  37. sql.append("';");
  38. }
  39. std::string Error;
  40. YADB::CDBResultSet DBRes;
  41. sDBConnPool.Query(sql.c_str(),DBRes,Error);
  42. int nCount = DBRes.GetRecordCount( Error );
  43. if (nCount < 1)
  44. {
  45. log_error("增加或修改失败,数据库中找不到: sql=%s", sql.c_str());
  46. return map;
  47. }
  48. while ( DBRes.GetNextRecod(Error) )
  49. {
  50. unsigned int vehicle_id = 0;
  51. DBRes.GetField( "vehicle_id",vehicle_id, Error );
  52. std::string card_id;
  53. DBRes.GetField( "card_id",card_id, Error );
  54. uint32_t vsid = atoi(card_id.substr(3).c_str());
  55. unsigned int card_type_id = 0;
  56. DBRes.GetField( "card_type_id",card_type_id, Error );
  57. int dept_id = 0;
  58. DBRes.GetField( "dept_id",dept_id, Error );
  59. int group_id = 0;
  60. DBRes.GetField( "group_id",group_id, Error );
  61. int vehicle_type_id = 0;
  62. DBRes.GetField( "vehicle_type_id",vehicle_type_id, Error );
  63. int vehicle_level_id = 0;
  64. DBRes.GetField( "vehicle_level_id",vehicle_level_id, Error );
  65. int need_display = 0;
  66. DBRes.GetField( "need_display",need_display, Error );
  67. int power_alarm = 0;
  68. DBRes.GetField( "power_alarm",power_alarm, Error );
  69. int vehicle_category_id = 0;
  70. DBRes.GetField( "vehicle_category_id",vehicle_category_id, Error );
  71. int bigger_car_flag= 0;
  72. DBRes.GetField( "bigger_car_flag",bigger_car_flag, Error );
  73. double over_speed= 0;
  74. DBRes.GetField( "over_speed",over_speed, Error );
  75. std::string strategy;
  76. if(card_type_id ==CT_VEHICLE)
  77. strategy = config.get("car.strategy","CS_1");
  78. else
  79. strategy = config.get("person.strategy","PS_1");
  80. auto clb = card_location_base::make_car(strategy,vsid,need_display,card_type_id,
  81. dept_id,vehicle_category_id, vehicle_type_id,vehicle_level_id,vehicle_id);
  82. uint64_t cardid = tool_other::type_id_to_u64(card_type_id,vsid);
  83. log_info("cardId:%llu,id:%d dept_id:%d,need_display:%d-cardid:%s,categoryid:%d,vchile_id:%d,type:%d",
  84. cardid,vsid,dept_id,need_display,card_id.c_str(),vehicle_category_id,vehicle_id,card_type_id);
  85. map.insert({cardid,clb});
  86. }
  87. return map;
  88. }
  89. std::unordered_map<uint64_t,std::shared_ptr<card_location_base>> load_person(const std::string & lszId64,const std::string&strategy)
  90. {
  91. std::string sql = "SELECT s.staff_id, s.card_id, c.card_type_id, s.dept_id, s.group_id, s.occupation_id, \
  92. ol.occupation_level_id,s.worktype_id,s.need_display,s.work_line\
  93. ,ds.name as staffer_name,dd.name as dept_name\
  94. FROM dat_staff_extend s \
  95. LEFT JOIN dat_staff ds ON ds.staff_id = s.staff_id \
  96. LEFT JOIN dat_dept dd ON dd.dept_id = s.dept_id \
  97. LEFT JOIN dat_card c ON s.card_id = c.card_id \
  98. LEFT JOIN dat_occupation o ON s.occupation_id = o.occupation_id \
  99. LEFT JOIN dat_occupation_level ol ON ol.occupation_level_id = o.occupation_level_id \
  100. WHERE s.duty_id = 0 AND c.state_id = 0";
  101. std::unordered_map<uint64_t,std::shared_ptr<card_location_base>> map;
  102. if("" == lszId64)
  103. {
  104. sql.append(";");
  105. }
  106. else
  107. {
  108. sql.append(" AND s.card_id = '");
  109. sql.append(lszId64);
  110. sql.append("';");
  111. }
  112. std::string Error;
  113. YADB::CDBResultSet DBRes;
  114. sDBConnPool.Query(sql.c_str(),DBRes,Error);
  115. int nCount = DBRes.GetRecordCount( Error );
  116. if (nCount < 1)
  117. {
  118. log_error("增加或修改失败,数据库中找不到: sql", sql.c_str());
  119. return map;
  120. }
  121. while ( DBRes.GetNextRecod(Error) )
  122. {
  123. unsigned int staff_id = 0;
  124. DBRes.GetField( "staff_id",staff_id, Error );
  125. std::string card_id;
  126. DBRes.GetField( "card_id",card_id, Error );
  127. uint32_t vsid = atoi(card_id.substr(3).c_str());
  128. unsigned int card_type_id = 0;
  129. DBRes.GetField( "card_type_id",card_type_id, Error );
  130. int dept_id = 0;
  131. DBRes.GetField( "dept_id",dept_id, Error );
  132. int group_id = 0;
  133. DBRes.GetField( "group_id",group_id, Error );
  134. int occupation_id = 0;
  135. DBRes.GetField( "occupation_id",occupation_id, Error );
  136. int occupation_level_id = 0;
  137. DBRes.GetField( "occupation_level_id",occupation_level_id, Error );
  138. int need_display = 0;
  139. DBRes.GetField( "need_display",need_display, Error );
  140. int work_line = 0;
  141. DBRes.GetField( "work_line",work_line, Error );
  142. std::string staffer_name;
  143. DBRes.GetField( "staffer_name",staffer_name, Error );
  144. std::string dept_name;
  145. DBRes.GetField( "dept_name",dept_name, Error );
  146. int worktype_id;
  147. DBRes.GetField( "worktype_id",worktype_id, Error );
  148. std::shared_ptr<card_location_base> clb =
  149. std::make_shared<person>(strategy,vsid,need_display,card_type_id,dept_id,occupation_level_id,staff_id,work_line,staffer_name,dept_name,worktype_id);
  150. uint64_t cardid = tool_other::type_id_to_u64(card_type_id,vsid);
  151. log_info("cardId:%llu,id:%d dept_id:%d,need_display:%d,card:%s:work_line:%d,staff_id:%d,type:%d,staffer_name:%s,dept_name:%s",
  152. cardid,vsid,dept_id,need_display,card_id.c_str(),work_line,staff_id,card_type_id,staffer_name.c_str(),dept_name.c_str());
  153. map.insert({cardid,clb});
  154. }
  155. return map;
  156. }
  157. }