xufenglei
2019-03-25 1830f5429730a40f7d2f17ca748a80a4b1046c21
src/main/resources/mapper/SensorMapper.xml
@@ -23,4 +23,103 @@
       where sen.id = dvs.sensor_id and dvs.device_version_id = #{deviceVersionId,jdbcType=INTEGER}
    )
  </select>
  <select id="selectByVersionNo" resultMap="BaseResultMap" parameterType="java.lang.Integer" >
    select
    <include refid="Base_Column_List" />
    from sensor sen
    where EXISTS
    (  select id
       from device_version_sensor dvs
       where sen.id = dvs.sensor_id
      and dvs.device_version_id in
        (
           select dev.id from device_version dev
             where dev.version = #{deviceVersionNo,jdbcType=INTEGER}
        )
    )
  </select>
  <select id="selectByVersionNos" resultMap="BaseResultMap" parameterType="java.util.List" >
    select
    <include refid="Base_Column_List" />
    from sensor sen
    where EXISTS
    (  select id
       from device_version_sensor dvs
       where sen.id = dvs.sensor_id
      and dvs.device_version_id in
        (
           select dev.id from device_version dev
              <where>
               1 > 1
               <if test="versionNos!=null and versionNos.size() > 0">
               or dev.version in
                 <foreach collection="versionNos" item="versionNo" open="(" close=")" separator=",">
                      #{versionNo,jdbcType=INTEGER}
                 </foreach>
               </if>
           </where>
        )
    )
  </select>
     <select id="getSensorsByDeviceVersionId" resultType="java.util.Map">
      SELECT
         s.*
      FROM
         device_version_sensor dvs,
         sensor s
      WHERE
         dvs.sensor_id = s.id
         AND dvs.device_version_id = #{deviceVersionId}
   </select>
     <select id="getSensorsByCriteria" resultMap="BaseResultMap">
      SELECT
         DISTINCT s.*
      FROM
         sensor s,
         device_version_sensor dvs,
         device d,
         monitor_point mp
      WHERE
         s.id = dvs.sensor_id
         AND dvs.device_version_id = d.device_version_id
         AND d.monitor_point_id = mp.id
         <if test="provinceCode != null">
         AND mp.province_code = #{provinceCode}
         </if>
         <if test="cityCode != null">
         AND mp.city_code = #{cityCode}
         </if>
         <if test="areaCode != null">
         AND mp.area_code = #{areaCode}
         </if>
         <if test="monitorPointId != null">
         AND mp.id =   #{monitorPointId}
         </if>
         <if test="mac != null">
         AND d.mac =   #{mac}
         </if>
         <if test="professionId != null">
         AND d.profession_id = #{professionId}
         </if>
   </select>
   <select id="selectByOrgId" resultMap="BaseResultMap">
        select * from sensor sen where sen.id in
         (
            select DISTINCT sensor_id from device_version_sensor dvs
             where dvs.device_version_id
             in (
                  select DISTINCT device_version_id from device dev where
                  EXISTS (select * from monitor_point mpt where
                   mpt.organization_id = #{organizationId,jdbcType=INTEGER} and mpt.id = dev.monitor_point_id
                   OR EXISTS  (
                                SELECT * from dictionary_data
                             where dict_data_key = 'auth_config_super_org' and dict_data_value = #{organizationId,jdbcType=INTEGER}
                             )
                         )
              )
           )
          order by sen.id asc
   </select>
</mapper>