lizijie
2019-06-12 09c3a7d258c7bde571f74050156437d2eb86c6c6
src/main/resources/mapper/SensorMapper.xml
@@ -23,6 +23,44 @@
       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
@@ -66,5 +104,22 @@
         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>