DayReportMapper.xml 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper
  3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <mapper namespace="com.huaxu.dao.DayReportMapper">
  6. <resultMap type="DayReportEntity" id="DayReportResult">
  7. <result property="id" column="id"/>
  8. <result property="tenantId" column="tenant_id"/>
  9. <result property="year" column="year"/>
  10. <result property="month" column="month"/>
  11. <result property="day" column="day"/>
  12. <result property="hour" column="hour"/>
  13. <result property="parentSceneId" column="parent_scene_id"/>
  14. <result property="parentSceneName" column="parent_scene_name"/>
  15. <result property="sceneId" column="scene_id"/>
  16. <result property="sceneName" column="scene_name"/>
  17. <result property="deviceId" column="device_id"/>
  18. <result property="deviceName" column="device_name"/>
  19. <result property="deviceCode" column="device_code"/>
  20. <result property="attributeId" column="attribute_id"/>
  21. <result property="attributeName" column="attribute_name"/>
  22. <result property="minValue" column="min_value"/>
  23. <result property="maxValue" column="max_value"/>
  24. <result property="avgValue" column="avg_value"/>
  25. <result property="sumValue" column="sum_value"/>
  26. <result property="latestValue" column="latest_value"/>
  27. <result property="collectDate" column="collect_date"/>
  28. <result property="dateCreate" column="date_create"/>
  29. <result property="createBy" column="create_by"/>
  30. <result property="dateUpdate" column="date_update"/>
  31. <result property="updateBy" column="update_by"/>
  32. </resultMap>
  33. <!-- 实体栏位 -->
  34. <sql id="dayReportColumns">
  35. a.id as "id" ,
  36. a.tenant_id as "tenantId" ,
  37. a.year as "year" ,
  38. a.month as "month" ,
  39. a.day as "day" ,
  40. a.hour as "hour" ,
  41. a.parent_scene_id as "parentSceneId" ,
  42. a.parent_scene_name as "parentSceneName" ,
  43. a.scene_id as "sceneId" ,
  44. a.scene_name as "sceneName" ,
  45. a.device_id as "deviceId" ,
  46. a.device_name as "deviceName" ,
  47. a.device_code as "deviceCode" ,
  48. a.attribute_id as "attributeId" ,
  49. a.attribute_name as "attributeName" ,
  50. a.min_value as "minValue" ,
  51. a.max_value as "maxValue" ,
  52. a.avg_value as "avgValue" ,
  53. a.sum_value as "sumValue" ,
  54. a.latest_value as "latestValue" ,
  55. a.collect_date as "collectDate" ,
  56. a.date_create as "dateCreate" ,
  57. a.create_by as "createBy" ,
  58. a.date_update as "dateUpdate" ,
  59. a.update_by as "updateBy"
  60. </sql>
  61. <!-- 根据主键获取实体 -->
  62. <select id="findDayReportById" resultType="com.huaxu.entity.DayReportEntity">
  63. SELECT
  64. <include refid="dayReportColumns"/>
  65. FROM sms_day_report a
  66. WHERE a.id = #{id}
  67. </select>
  68. <!-- 根据获取实体List -->
  69. <select id="findList" resultType="com.huaxu.entity.DayReportEntity">
  70. SELECT
  71. <include refid="dayReportColumns"/>
  72. FROM sms_day_report a
  73. <where>
  74. <if test="tenantId != null and tenantId != ''">and a.tenant_id = #{tenantId}</if>
  75. <if test="year != null ">and a.year = #{year}</if>
  76. <if test="month != null ">and a.month = #{month}</if>
  77. <if test="day != null ">and a.day = #{day}</if>
  78. <if test="hour != null ">and a.hour = #{hour}</if>
  79. <if test="parentSceneId != null ">and a.parent_scene_id = #{parentSceneId}</if>
  80. <if test="sceneId != null ">and a.scene_id = #{sceneId}</if>
  81. <if test="deviceId != null ">and a.device_id = #{deviceId}</if>
  82. <if test="deviceCode != null and deviceCode != ''">and a.device_code = #{deviceCode}</if>
  83. <if test="attributeId != null ">and a.attribute_id = #{attributeId}</if>
  84. <if test="collectDate != null ">and a.collect_date = #{collectDate}</if>
  85. </where>
  86. </select>
  87. <!-- 根据获取实体 page -->
  88. <select id="findPage" resultType="com.huaxu.dto.ReportDto">
  89. SELECT
  90. distinct
  91. a.tenant_id as "tenantId" ,
  92. a.year as "year" ,
  93. a.month as "month" ,
  94. a.day as "day" ,
  95. a.hour as "hour" ,
  96. b.parent_scene_id as "parentSceneId",
  97. c.SCENE_NAME as "parentSceneName"
  98. FROM sms_day_report a
  99. inner join sms_device_parm b on a.DEVICE_ID = b.DEVICE_ID and a.ATTRIBUTE_ID=b.ATTRIBUTE_ID and b.`STATUS`=1
  100. inner join sms_scene c on b.PARENT_SCENE_ID=c.id
  101. <where>
  102. b.IS_REPORT=1
  103. <if test="dayReport.tenantId != null and dayReport.tenantId != ''">and a.tenant_id =
  104. #{dayReport.tenantId}
  105. </if>
  106. <if test="dayReport.year != null ">and a.year = #{dayReport.year}</if>
  107. <if test="dayReport.month != null ">and a.month = #{dayReport.month}</if>
  108. <if test="dayReport.day != null ">and a.day = #{dayReport.day}</if>
  109. and b.parent_scene_id in
  110. <foreach collection="dayReport.parentSceneIds" item="dramaId" open="(" close=")" separator=",">
  111. #{dramaId}
  112. </foreach>
  113. </where>
  114. order by b.parent_scene_id,a.year,a.month,a.day,a.hour
  115. </select>
  116. <select id="findAttributeList" resultType="com.huaxu.dto.ReportAttributeDto">
  117. SELECT tab.attributeName,tab.ATTRIBUTE_TYPE,min(tab.minValue) as "minValue",
  118. max(tab.maxValue) as "maxValue",AVG(tab.avgValue)as "avgValue",
  119. AVG(tab.sumValue)as "sumValue",AVG(tab.latestValue) as "latestValue"
  120. from
  121. (SELECT IFNULL(a.REMARK,b.`NAME`) AS "attributeName",
  122. c.min_value as "minValue" ,c.max_value as "maxValue" ,c.avg_value as "avgValue" ,
  123. c.sum_value as "sumValue" ,c.latest_value as "latestValue",
  124. a.PARM_TYPE as ATTRIBUTE_TYPE
  125. FROM sms_device_parm a
  126. INNER JOIN sms_device_attribute b on a.ATTRIBUTE_ID=b.ID
  127. INNER JOIN sms_day_report c on a.ATTRIBUTE_ID=c.ATTRIBUTE_ID and a.DEVICE_ID=c.DEVICE_ID
  128. where
  129. a.IS_REPORT=1 and a.`STATUS`=1
  130. <if test="report.deviceIds != null and report.deviceIds.size() > 0">
  131. and a.DEVICE_ID in
  132. <foreach collection="report.deviceIds" item="dramaId" open="(" close=")" separator=",">
  133. #{dramaId.id}
  134. </foreach>
  135. </if>
  136. <if test="report.year != null ">and c.`YEAR`=#{report.year}</if>
  137. <if test="report.month != null ">and c.`MONTH`=#{report.month}</if>
  138. <if test="report.day != null ">and c.`DAY`=#{report.day}</if>
  139. <if test="report.hour != null ">and c.`HOUR`=#{report.hour}</if>
  140. <if test="report.parentSceneId != null ">and a.PARENT_SCENE_ID=#{report.parentSceneId}</if>
  141. ORDER BY a.SEQ
  142. ) as tab
  143. group by tab.attributeName,tab.ATTRIBUTE_TYPE
  144. </select>
  145. <select id="findReport" resultType="com.huaxu.dto.ReportDto">
  146. select
  147. tab.year,tab.month,tab.day,tab.hour,
  148. sum(ifnull(intakeWaterUsage,0))as "intakeWaterUsage",
  149. sum(ifnull(yieldWaterUsage,0))as "yieldWaterUsage",
  150. sum(ifnull(powerUsage,0))as "powerUsage",
  151. sum(ifnull(drugUsage,0))as "drugUsage"
  152. from
  153. (SELECT
  154. c.year,c.month,c.day,c.hour,
  155. case when a.PARM_TYPE=4 then
  156. c.latest_value end as "intakeWaterUsage",
  157. case when a.PARM_TYPE=3 then
  158. c.latest_value end as "yieldWaterUsage",
  159. case when a.PARM_TYPE=5 then
  160. c.latest_value end as "powerUsage",
  161. case when a.PARM_TYPE=6 then
  162. c.latest_value end as "drugUsage"
  163. FROM sms_device_parm a
  164. INNER JOIN sms_device_attribute b on a.ATTRIBUTE_ID=b.ID
  165. INNER JOIN sms_day_report c on a.ATTRIBUTE_ID=c.ATTRIBUTE_ID and a.DEVICE_ID=c.DEVICE_ID
  166. where
  167. <if test="report.deviceIds != null and report.deviceIds.size() > 0">
  168. a.DEVICE_ID in
  169. <foreach collection="report.deviceIds" item="dramaId" open="(" close=")" separator=",">
  170. #{dramaId.id}
  171. </foreach>
  172. </if>
  173. <if test="report.year != null ">and c.`YEAR`=#{report.year}</if>
  174. <if test="report.month != null ">and c.`MONTH`=#{report.month}</if>
  175. <if test="report.day != null ">and c.`DAY`=#{report.day}</if>
  176. <if test="report.parentSceneId != null ">and a.PARENT_SCENE_ID=#{report.parentSceneId}</if>
  177. and (a.PARM_TYPE =3 or a.PARM_TYPE =4 or a.PARM_TYPE =5 or a.PARM_TYPE =6) and a.`STATUS`=1) tab
  178. group by tab.year,tab.month,tab.day,tab.HOUR
  179. order by tab.year desc,tab.month desc,tab.day desc,tab.hour desc
  180. </select>
  181. <!-- 根据获取实体 page -->
  182. <select id="findDevicePressPage" resultType="com.huaxu.dto.DevicePressReportAttributeDto">
  183. SELECT
  184. a.DEVICE_CODE as "deviceCode",
  185. a.DEVICE_NAME as "deviceName",
  186. a.min_value as "minValue" ,a.max_value as "maxValue" ,a.avg_value as "avgValue" ,
  187. a.sum_value as "sumValue" ,a.latest_value as "latestValue",
  188. a.COLLECT_DATE as "collectDate"
  189. FROM sms_day_report a
  190. inner join sms_device d on d.id = a.DEVICE_ID
  191. inner join sms_device_parm b on a.DEVICE_ID = b.DEVICE_ID and a.ATTRIBUTE_ID=b.ATTRIBUTE_ID and b.`STATUS`=1
  192. <if test="dayReport.type == 1">
  193. and b.PARM_TYPE = 13
  194. </if>
  195. <if test="dayReport.type == 2">
  196. and b.PARM_TYPE = 14
  197. </if>
  198. <where>
  199. <if test="dayReport.tenantId != null and dayReport.tenantId != ''">and a.tenant_id =
  200. #{dayReport.tenantId}
  201. </if>
  202. <if test="dayReport.year != null ">and a.year = #{dayReport.year}</if>
  203. <if test="dayReport.month != null ">and a.month = #{dayReport.month}</if>
  204. <if test="dayReport.day != null ">and a.day = #{dayReport.day}</if>
  205. and a.DEVICE_ID in
  206. <foreach collection="dayReport.deviceIds" item="dramaId" open="(" close=")" separator=",">
  207. #{dramaId.id}
  208. </foreach>
  209. </where>
  210. order by a.DEVICE_ID,a.year,a.month,a.day,a.hour
  211. </select>
  212. <!-- 根据获取实体 page -->
  213. <select id="findDeviceWaterPage" resultType="com.huaxu.dto.DeviceWaterReportAttributeDto">
  214. select tab.deviceCode,tab.deviceName,tab.collectDate,
  215. sum(tab.minPHValue) as minPHValue,sum(tab.maxPHValue) as maxPHValue,sum(tab.avgPHValue) as avgPHValue,sum(tab.sumPHValue) as sumPHValue,sum(tab.latestPHValue) as latestPHValue,
  216. sum(tab.minQuValue) as minQuValue,sum(tab.maxQuValue) as maxQuValue,sum(tab.avgQuValue) as avgQuValue,sum(tab.sumQuValue) as sumQuValue,sum(tab.latestQuValue) as latestQuValue,
  217. sum(tab.minCLValue) as minCLValue,sum(tab.maxCLValue) as maxCLValue,sum(tab.avgCLValue) as avgCLValue,sum(tab.sumCLValue) as sumCLValue,sum(tab.latestCLValue) as latestCLValue
  218. from (
  219. SELECT a.DEVICE_ID,a.id,a.DEVICE_CODE as "deviceCode", a.DEVICE_NAME as "deviceName",
  220. case when b.PARM_TYPE=7 then a.min_value end as "minPHValue" ,
  221. case when b.PARM_TYPE=7 then a.max_value end as "maxPHValue" ,
  222. case when b.PARM_TYPE=7 then a.avg_value end as "avgPHValue" ,
  223. case when b.PARM_TYPE=7 then a.sum_value end as "sumPHValue" ,
  224. case when b.PARM_TYPE=7 then a.latest_value end as "latestPHValue",
  225. case when b.PARM_TYPE=9 then a.min_value end as "minQuValue" ,
  226. case when b.PARM_TYPE=9 then a.max_value end as "maxQuValue" ,
  227. case when b.PARM_TYPE=9 then a.avg_value end as "avgQuValue" ,
  228. case when b.PARM_TYPE=9 then a.sum_value end as "sumQuValue" ,
  229. case when b.PARM_TYPE=9 then a.latest_value end as "latestQuValue",
  230. case when b.PARM_TYPE=11 then a.min_value end as "minCLValue" ,
  231. case when b.PARM_TYPE=11 then a.max_value end as "maxCLValue" ,
  232. case when b.PARM_TYPE=11 then a.avg_value end as "avgCLValue" ,
  233. case when b.PARM_TYPE=11 then a.sum_value end as "sumCLValue" ,
  234. case when b.PARM_TYPE=11 then a.latest_value end as "latestCLValue",
  235. a.COLLECT_DATE as "collectDate" ,
  236. a.year,a.month,a.day,a.hour
  237. FROM sms_day_report a
  238. inner join sms_device d on d.id = a.DEVICE_ID
  239. inner join sms_device_parm b on a.DEVICE_ID = b.DEVICE_ID and a.ATTRIBUTE_ID=b.ATTRIBUTE_ID and b.`STATUS`=1
  240. and (b.PARM_TYPE = 7 or b.PARM_TYPE = 10 or b.PARM_TYPE = 11)
  241. <where>
  242. <if test="dayReport.tenantId != null and dayReport.tenantId != ''">and a.tenant_id =
  243. #{dayReport.tenantId}
  244. </if>
  245. <if test="dayReport.year != null ">and a.year = #{dayReport.year}</if>
  246. <if test="dayReport.month != null ">and a.month = #{dayReport.month}</if>
  247. <if test="dayReport.day != null ">and a.day = #{dayReport.day}</if>
  248. and a.DEVICE_ID in
  249. <foreach collection="dayReport.deviceIds" item="dramaId" open="(" close=")" separator=",">
  250. #{dramaId.id}
  251. </foreach>
  252. </where>) as tab
  253. group by tab.DEVICE_ID,tab.year,tab.month,tab.day,tab.hour,tab.deviceCode,tab.deviceName,tab.collectDate
  254. order by tab.DEVICE_ID,tab.year,tab.month,tab.day,tab.hour
  255. </select>
  256. <select id="findDeviceLastDayValue" resultType="com.huaxu.entity.DayReportEntity">
  257. select a.LATEST_VALUE as "latestValue"
  258. from sms_day_report a
  259. where a.ATTRIBUTE_ID= #{dayReport.attributeId} and a.DEVICE_ID=#{dayReport.deviceId}
  260. <if test="dayReport.year != null ">and a.year = #{dayReport.year}</if>
  261. <if test="dayReport.month != null ">and a.month = #{dayReport.month}</if>
  262. <if test="dayReport.day != null ">and a.day = #{dayReport.day}</if>
  263. order by a.COLLECT_DATE DESC
  264. limit 1
  265. </select>
  266. </mapper>