HouseNumberStatusImplDao.java 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  1. package com.happy.dao.impl;
  2. import com.happy.Model.Booking;
  3. import com.happy.Model.Holiday;
  4. import com.happy.Model.HouseNumber;
  5. import com.happy.Model.HouseNumberStatus;
  6. import com.happy.Until.BeanMapTool;
  7. import com.happy.Until.SqlUtil;
  8. import com.happy.Until.UUIDUtil;
  9. import com.happy.dao.HouseNumberDao;
  10. import com.happy.dao.HouseNumberStatusDao;
  11. import com.happy.dto.HouseNumberStatusDto;
  12. import org.apache.commons.lang.StringUtils;
  13. import org.springframework.beans.factory.annotation.Autowired;
  14. import org.springframework.jdbc.core.BeanPropertyRowMapper;
  15. import org.springframework.jdbc.core.namedparam.MapSqlParameterSource;
  16. import org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate;
  17. import org.springframework.jdbc.core.namedparam.SqlParameterSource;
  18. import org.springframework.jdbc.core.namedparam.SqlParameterSourceUtils;
  19. import org.springframework.stereotype.Repository;
  20. import java.util.ArrayList;
  21. import java.util.List;
  22. import java.util.Map;
  23. import java.util.UUID;
  24. @Repository("HouseNumberStatusDao")
  25. public class HouseNumberStatusImplDao implements HouseNumberStatusDao {
  26. @Autowired
  27. private NamedParameterJdbcTemplate namedParameterJdbcTemplate;
  28. public NamedParameterJdbcTemplate getNamedParameterJdbcTemplate() {
  29. return namedParameterJdbcTemplate;
  30. }
  31. public void setNamedParameterJdbcTemplate(NamedParameterJdbcTemplate namedParameterJdbcTemplate) {
  32. this.namedParameterJdbcTemplate = namedParameterJdbcTemplate;
  33. }
  34. /**
  35. * 按年份删除节假日数据
  36. *
  37. * @param year 年份
  38. * @return
  39. */
  40. @Override
  41. public int deleteHolidayByYear(String year) {
  42. String sql = "delete from holiday where year = :year";
  43. MapSqlParameterSource sps = new MapSqlParameterSource();
  44. sps.addValue("year", year);
  45. int num = 0;
  46. try {
  47. num = namedParameterJdbcTemplate.update(sql, sps);
  48. } catch (Exception e) {
  49. e.printStackTrace();
  50. }
  51. return num;
  52. }
  53. /**
  54. * 2023-09-20 a-jax 批量新增节假日数据
  55. *
  56. * @param list
  57. * @return
  58. */
  59. @Override
  60. public int saveHolidayBatch(List<Holiday> list) {
  61. SqlParameterSource[] params = SqlParameterSourceUtils.createBatch(list.toArray());
  62. String insertSql = "INSERT INTO holiday (id, year, date, is_rest, name)" +
  63. " VALUES " +
  64. " (:id,:year,:date,:isRest,:name) ";
  65. List<MapSqlParameterSource> houseNumberList = new ArrayList<>();
  66. for (Holiday h1 : list) {
  67. MapSqlParameterSource mapSqlParameterSource = new MapSqlParameterSource();
  68. mapSqlParameterSource.addValue("id", h1.getId());
  69. mapSqlParameterSource.addValue("year", h1.getYear());
  70. mapSqlParameterSource.addValue("date", h1.getDate());
  71. mapSqlParameterSource.addValue("isRest", h1.getIsRest());
  72. mapSqlParameterSource.addValue("name", h1.getName());
  73. houseNumberList.add(mapSqlParameterSource);
  74. }
  75. int[] m = namedParameterJdbcTemplate.batchUpdate(insertSql, houseNumberList.toArray(new SqlParameterSource[0]));
  76. return m.length;
  77. }
  78. /**
  79. * 根据开始时间和年份查询节假日数据
  80. */
  81. public List<Holiday> queryHolidays(String year, String startDate, String endDates) {
  82. String sql = "select * from holiday where date >=:startDate and date <=:endDate and year =:year order by date";
  83. MapSqlParameterSource sps = new MapSqlParameterSource();
  84. sps.addValue("startDate", startDate);
  85. sps.addValue("endDate", endDates);
  86. sps.addValue("year", year);
  87. List<Holiday> list = namedParameterJdbcTemplate.query(sql, sps, new BeanPropertyRowMapper<>(Holiday.class));
  88. if (list != null && list.size() > 0) {
  89. return list;
  90. }
  91. return null;
  92. }
  93. @Override
  94. public int saveBatch(List<HouseNumberStatus> list) {
  95. SqlParameterSource[] params = SqlParameterSourceUtils.createBatch(list.toArray());
  96. String insertSql = "INSERT INTO `house_number_status` (`id`, `number_id`, `booking_id`, `close_type`, `remark`, `set_date`, `create_id`, `create_date` , `modify_date` , `status` )" +
  97. " VALUES " +
  98. " (:id,:numberId,:bookingId,:closeType,:remark,:setDate,:createId,:createDate,:modifyDate,:status) ";
  99. int[] m = namedParameterJdbcTemplate.batchUpdate(insertSql, params);
  100. return m.length;
  101. }
  102. @Override
  103. public int updateHouseNumberStatus(String bookId) {
  104. StringBuffer stringBuffer = new StringBuffer("update house_number_status set status = :status, modify_date = :modifyDate");
  105. MapSqlParameterSource sps = new MapSqlParameterSource();
  106. stringBuffer.append(" where booking_id=:booking_id ");
  107. sps.addValue("status", 0);
  108. sps.addValue("booking_id", bookId);
  109. sps.addValue("modifyDate", UUIDUtil.getNewDate());
  110. int num = 0;
  111. try {
  112. num = namedParameterJdbcTemplate.update(stringBuffer.toString(), sps);
  113. } catch (Exception e) {
  114. e.printStackTrace();
  115. }
  116. return num;
  117. }
  118. @Override
  119. public void updateStatus(HouseNumberStatusDto houseNumberStatusDto) {
  120. StringBuilder sql = new StringBuilder("update house_number_status set status = :status, modify_date = :modifyDate");
  121. if (StringUtils.isNotBlank(houseNumberStatusDto.getRemark())) {
  122. sql.append(", remark = :remark");
  123. }
  124. sql.append(" where status != 0");
  125. Map<String, Object> paramMap = buildParamMap(houseNumberStatusDto);
  126. houseNumberStatusDto.setStatus(null);
  127. StringBuilder sqlLast = buildSql(sql.toString(), "", houseNumberStatusDto);
  128. namedParameterJdbcTemplate.update(sqlLast.toString(), paramMap);
  129. }
  130. @Override
  131. public List<HouseNumberStatusDto> queryList(HouseNumberStatusDto houseNumberStatusDto) {
  132. final String SQL_HEAD = "select id, number_id, booking_id, close_type, remark, date_format(set_date, '%Y-%m-%d') as set_date, create_id, date_format(create_date, '%Y-%m-%d %H:%i:%s') as create_date, date_format(modify_date, '%Y-%m-%d %H:%i:%s') as modify_date, status from house_number_status where 1 = 1";
  133. final String SQL_TAIL = "order by create_date desc ";
  134. Map<String, Object> paramMap = buildParamMap(houseNumberStatusDto);
  135. StringBuilder sql = buildSql(SQL_HEAD, SQL_TAIL, houseNumberStatusDto);
  136. return namedParameterJdbcTemplate.query(sql.toString(), paramMap, new BeanPropertyRowMapper<>(HouseNumberStatusDto.class));
  137. }
  138. @Override
  139. public List<HouseNumberStatusDto> queryOrderSomeColumnListByIds(List<String> ids) {
  140. final String sql = "select id as bookingId, order_num, user_name as orderUserName, user_phone as orderUserPhone, pay_account as orderPayAccount, date_format(order_start_time, '%Y-%m-%d %H:%i:%s') as order_start_time, date_format(order_end_time, '%Y-%m-%d %H:%i:%s') as order_end_time from booking where id in (:ids)";
  141. return namedParameterJdbcTemplate.query(sql, new MapSqlParameterSource() {{
  142. addValue("ids", ids);
  143. }}, new BeanPropertyRowMapper<>(HouseNumberStatusDto.class));
  144. }
  145. @Override
  146. public List<HouseNumberStatus> getList(String sqlx) {
  147. SqlUtil.filterKeyword(sqlx);
  148. String sql = "select id, number_id, booking_id, close_type, remark, date_format(set_date, '%Y-%m-%d') as set_date, create_id, date_format(create_date, '%Y-%m-%d %H:%i:%s') as create_date, date_format(modify_date, '%Y-%m-%d %H:%i:%s') as modify_date, status from house_number_status where 1 = 1 and status != 0" + sqlx;
  149. List<HouseNumberStatus> list = null;
  150. try {
  151. list = namedParameterJdbcTemplate.query(sql, new BeanPropertyRowMapper<>(HouseNumberStatus.class));
  152. } catch (Exception e) {
  153. e.printStackTrace();
  154. }
  155. if (list != null && list.size() > 0) return list;
  156. return null;
  157. }
  158. private StringBuilder buildSql(String sqlHead, String sqlTail, HouseNumberStatusDto houseNumberStatusDto) {
  159. StringBuilder sql = new StringBuilder(sqlHead);
  160. if (StringUtils.isNotBlank(houseNumberStatusDto.getNumberId())) {
  161. sql.append(" and number_id = :numberId");
  162. }
  163. if (houseNumberStatusDto.getHouseNumberIds() != null && !houseNumberStatusDto.getHouseNumberIds().isEmpty()) {
  164. sql.append(" and number_id in (:houseNumberIds)");
  165. }
  166. String setDate = houseNumberStatusDto.getSetDate();
  167. if (StringUtils.isNotBlank(setDate)) {
  168. String[] setDateArr = setDate.split(",");
  169. if (setDateArr.length == 1) {
  170. sql.append(" and date_format(set_date, '%Y-%m-%d') = :setDate");
  171. } else {
  172. sql.append(" and (date_format(set_date, '%Y-%m-%d')")
  173. .append(String.format(" between :%s and :%s)", HousePriceDaoImpl.KEY_START_SET_DATE, HousePriceDaoImpl.KEY_END_SET_DATE));
  174. }
  175. }
  176. if (houseNumberStatusDto.getStatus() != null) {
  177. sql.append(" and status = :status");
  178. }
  179. if (houseNumberStatusDto.getStatuses() != null && !houseNumberStatusDto.getStatuses().isEmpty()) {
  180. sql.append(" and status in (:statuses)");
  181. }
  182. sql.append(sqlTail);
  183. return sql;
  184. }
  185. private Map<String, Object> buildParamMap(HouseNumberStatusDto houseNumberStatusDto) {
  186. Map<String, Object> paramMap = BeanMapTool.beanToMap(houseNumberStatusDto);
  187. String setDate = houseNumberStatusDto.getSetDate();
  188. if (StringUtils.isNotBlank(setDate) && setDate.split(",").length == 2) {
  189. String[] setDateArr = setDate.split(",");
  190. paramMap.put(HousePriceDaoImpl.KEY_START_SET_DATE, setDateArr[0]);
  191. paramMap.put(HousePriceDaoImpl.KEY_END_SET_DATE, setDateArr[1]);
  192. }
  193. return paramMap;
  194. }
  195. }