HouseNumberStatusImplDao.java 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  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. * @param year ??
  37. * @return
  38. */
  39. @Override
  40. public int deleteHolidayByYear(String year) {
  41. String sql = "delete from holiday where year = :year";
  42. MapSqlParameterSource sps = new MapSqlParameterSource();
  43. sps.addValue("year",year);
  44. int num = 0;
  45. try{
  46. num = namedParameterJdbcTemplate.update(sql, sps);
  47. }
  48. catch(Exception e){
  49. e.printStackTrace();
  50. }
  51. return num;
  52. }
  53. /**
  54. * 2023-09-20 a-jax ?????????
  55. * @param list
  56. * @return
  57. */
  58. @Override
  59. public int saveHolidayBatch(List<Holiday> list) {
  60. SqlParameterSource[] params = SqlParameterSourceUtils.createBatch(list.toArray());
  61. String insertSql = "INSERT INTO holiday (id, year, date, is_rest, name)" +
  62. " VALUES " +
  63. " (:id,:year,:date,:isRest,:name) ";
  64. List<MapSqlParameterSource> houseNumberList = new ArrayList<>();
  65. for (Holiday h1 : list) {
  66. MapSqlParameterSource mapSqlParameterSource = new MapSqlParameterSource();
  67. mapSqlParameterSource.addValue("id", h1.getId());
  68. mapSqlParameterSource.addValue("year", h1.getYear());
  69. mapSqlParameterSource.addValue("date", h1.getDate());
  70. mapSqlParameterSource.addValue("isRest", h1.getIsRest());
  71. mapSqlParameterSource.addValue("name", h1.getName());
  72. houseNumberList.add(mapSqlParameterSource);
  73. }
  74. int[] m = namedParameterJdbcTemplate.batchUpdate(insertSql, houseNumberList.toArray(new SqlParameterSource[0]));
  75. return m.length;
  76. }
  77. @Override
  78. public int saveBatch(List<HouseNumberStatus> list) {
  79. SqlParameterSource[] params = SqlParameterSourceUtils.createBatch(list.toArray());
  80. String insertSql = "INSERT INTO `house_number_status` (`id`, `number_id`, `booking_id`, `close_type`, `remark`, `set_date`, `create_id`, `create_date` , `modify_date` , `status` )" +
  81. " VALUES " +
  82. " (:id,:numberId,:bookingId,:closeType,:remark,:setDate,:createId,:createDate,:modifyDate,:status) ";
  83. int[] m = namedParameterJdbcTemplate.batchUpdate(insertSql, params);
  84. return m.length;
  85. }
  86. @Override
  87. public int updateHouseNumberStatus(String bookId) {
  88. StringBuffer stringBuffer = new StringBuffer("update house_number_status set status = :status, modify_date = :modifyDate");
  89. MapSqlParameterSource sps = new MapSqlParameterSource();
  90. stringBuffer.append(" where booking_id=:booking_id ");
  91. sps.addValue("status",0);
  92. sps.addValue("booking_id",bookId);
  93. sps.addValue("modifyDate", UUIDUtil.getNewDate());
  94. int num = 0;
  95. try{
  96. num = namedParameterJdbcTemplate.update(stringBuffer.toString(), sps);
  97. }
  98. catch(Exception e){
  99. e.printStackTrace();
  100. }
  101. return num;
  102. }
  103. @Override
  104. public void updateStatus(HouseNumberStatusDto houseNumberStatusDto) {
  105. StringBuilder sql = new StringBuilder("update house_number_status set status = :status, modify_date = :modifyDate");
  106. if (StringUtils.isNotBlank(houseNumberStatusDto.getRemark())) {
  107. sql.append(", remark = :remark");
  108. }
  109. sql.append(" where status != 0");
  110. Map<String, Object> paramMap = buildParamMap(houseNumberStatusDto);
  111. houseNumberStatusDto.setStatus(null);
  112. StringBuilder sqlLast = buildSql(sql.toString(), "", houseNumberStatusDto);
  113. namedParameterJdbcTemplate.update(sqlLast.toString(), paramMap);
  114. }
  115. @Override
  116. public List<HouseNumberStatusDto> queryList(HouseNumberStatusDto houseNumberStatusDto) {
  117. 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";
  118. final String SQL_TAIL = "order by create_date desc ";
  119. Map<String, Object> paramMap = buildParamMap(houseNumberStatusDto);
  120. StringBuilder sql = buildSql(SQL_HEAD, SQL_TAIL, houseNumberStatusDto);
  121. return namedParameterJdbcTemplate.query(sql.toString(), paramMap, new BeanPropertyRowMapper<>(HouseNumberStatusDto.class));
  122. }
  123. @Override
  124. public List<HouseNumberStatusDto> queryOrderSomeColumnListByIds(List<String> ids) {
  125. 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)";
  126. return namedParameterJdbcTemplate.query(sql, new MapSqlParameterSource() {{
  127. addValue("ids", ids);
  128. }}, new BeanPropertyRowMapper<>(HouseNumberStatusDto.class));
  129. }
  130. @Override
  131. public List<HouseNumberStatus> getList(String sqlx) {
  132. SqlUtil.filterKeyword(sqlx);
  133. 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;
  134. List<HouseNumberStatus> list = null;
  135. try{
  136. list = namedParameterJdbcTemplate.query(sql, new BeanPropertyRowMapper<>(HouseNumberStatus.class));
  137. }catch (Exception e){
  138. e.printStackTrace();
  139. }
  140. if(list != null && list.size()>0) return list;
  141. return null;
  142. }
  143. private StringBuilder buildSql(String sqlHead, String sqlTail, HouseNumberStatusDto houseNumberStatusDto) {
  144. StringBuilder sql = new StringBuilder(sqlHead);
  145. if (StringUtils.isNotBlank(houseNumberStatusDto.getNumberId())) {
  146. sql.append(" and number_id = :numberId");
  147. }
  148. if (houseNumberStatusDto.getHouseNumberIds() != null && !houseNumberStatusDto.getHouseNumberIds().isEmpty()) {
  149. sql.append(" and number_id in (:houseNumberIds)");
  150. }
  151. String setDate = houseNumberStatusDto.getSetDate();
  152. if (StringUtils.isNotBlank(setDate)) {
  153. String[] setDateArr = setDate.split(",");
  154. if (setDateArr.length == 1) {
  155. sql.append(" and date_format(set_date, '%Y-%m-%d') = :setDate");
  156. } else {
  157. sql.append(" and (date_format(set_date, '%Y-%m-%d')")
  158. .append(String.format(" between :%s and :%s)", HousePriceDaoImpl.KEY_START_SET_DATE, HousePriceDaoImpl.KEY_END_SET_DATE));
  159. }
  160. }
  161. if (houseNumberStatusDto.getStatus() != null) {
  162. sql.append(" and status = :status");
  163. }
  164. if (houseNumberStatusDto.getStatuses() != null && !houseNumberStatusDto.getStatuses().isEmpty()) {
  165. sql.append(" and status in (:statuses)");
  166. }
  167. sql.append(sqlTail);
  168. return sql;
  169. }
  170. private Map<String, Object> buildParamMap(HouseNumberStatusDto houseNumberStatusDto) {
  171. Map<String, Object> paramMap = BeanMapTool.beanToMap(houseNumberStatusDto);
  172. String setDate = houseNumberStatusDto.getSetDate();
  173. if (StringUtils.isNotBlank(setDate) && setDate.split(",").length == 2) {
  174. String[] setDateArr = setDate.split(",");
  175. paramMap.put(HousePriceDaoImpl.KEY_START_SET_DATE, setDateArr[0]);
  176. paramMap.put(HousePriceDaoImpl.KEY_END_SET_DATE, setDateArr[1]);
  177. }
  178. return paramMap;
  179. }
  180. }