<?xml version="1.0" encoding="UTF-8" ?>
|
<!DOCTYPE mapper
|
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
<mapper namespace="com.fastbee.iot.mapper.DeviceUserMapper">
|
|
<resultMap type="com.fastbee.iot.domain.DeviceUser" id="DeviceUserResult">
|
<result property="deviceId" column="device_id" />
|
<result property="userId" column="user_id" />
|
<result property="deviceName" column="device_name" />
|
<result property="userName" column="user_name" />
|
<result property="isOwner" column="is_owner" />
|
<result property="tenantId" column="tenant_id" />
|
<result property="tenantName" column="tenant_name" />
|
<result property="phonenumber" column="phonenumber" />
|
<result property="perms" column="perms" />
|
<result property="createTime" column="create_time" />
|
<result property="updateTime" column="update_time" />
|
<result property="remark" column="remark" />
|
</resultMap>
|
|
<resultMap type="com.fastbee.common.core.domain.entity.SysUser" id="ShareUserResult">
|
<id property="userId" column="user_id" />
|
<result property="userName" column="user_name" />
|
<result property="nickName" column="nick_name" />
|
<result property="email" column="email" />
|
<result property="phonenumber" column="phonenumber" />
|
<result property="sex" column="sex" />
|
<result property="avatar" column="avatar" />
|
<result property="createTime" column="create_time" />
|
<result property="remark" column="remark" />
|
</resultMap>
|
|
<sql id="selectDeviceUserVo">
|
select device_id, user_id, device_name, user_name, is_owner,tenant_id,tenant_name,phonenumber,perms, create_time, update_time, remark from iot_device_user
|
</sql>
|
|
<select id="selectShareUser" parameterType="com.fastbee.iot.domain.DeviceUser" resultMap="ShareUserResult">
|
select u.user_id, u.nick_name, u.user_name, u.email, u.avatar, u.phonenumber, u.sex, u.create_time from sys_user u
|
left join (select * from iot_device_user where iot_device_user.device_id=#{deviceId}) d on u.user_id = d.user_id
|
where u.del_flag = '0' and u.status=0 and u.phonenumber = #{phonenumber} and d.device_id is null
|
</select>
|
|
<select id="selectDeviceUserList" parameterType="com.fastbee.iot.domain.DeviceUser" resultMap="DeviceUserResult">
|
<include refid="selectDeviceUserVo"/>
|
<where>
|
<if test="1==1"> and device_id = #{deviceId}</if>
|
<if test="userId != null and userId != 0"> and user_id = #{userId}</if>
|
</where>
|
</select>
|
|
<select id="selectDeviceUserByDeviceId" parameterType="Long" resultMap="DeviceUserResult">
|
<include refid="selectDeviceUserVo"/>
|
where device_id = #{deviceId}
|
</select>
|
|
<select id="selectDeviceUserByDeviceIdAndUserId" resultMap="DeviceUserResult">
|
<include refid="selectDeviceUserVo"/>
|
where device_id = #{deviceId} and user_id = #{userId}
|
</select>
|
|
<insert id="insertDeviceUser" parameterType="com.fastbee.iot.domain.DeviceUser" keyProperty="deviceId">
|
insert into iot_device_user
|
<trim prefix="(" suffix=")" suffixOverrides=",">
|
<if test="deviceId != null">device_id,</if>
|
<if test="userId != null">user_id,</if>
|
<if test="deviceName != null and deviceName != ''">device_name,</if>
|
<if test="userName != null and userName != ''">user_name,</if>
|
<if test="isOwner != null">is_owner,</if>
|
<if test="tenantId != null">tenant_id,</if>
|
<if test="tenantName != null">tenant_name,</if>
|
<if test="phonenumber != null">phonenumber,</if>
|
<if test="perms != null">perms,</if>
|
<if test="delFlag != null">del_flag,</if>
|
<if test="createBy != null">create_by,</if>
|
<if test="createTime != null">create_time,</if>
|
<if test="updateBy != null">update_by,</if>
|
<if test="updateTime != null">update_time,</if>
|
<if test="remark != null">remark,</if>
|
</trim>
|
<trim prefix="values (" suffix=")" suffixOverrides=",">
|
<if test="deviceId != null">#{deviceId},</if>
|
<if test="userId != null">#{userId},</if>
|
<if test="deviceName != null and deviceName != ''">#{deviceName},</if>
|
<if test="userName != null and userName != ''">#{userName},</if>
|
<if test="isOwner != null">#{isOwner},</if>
|
<if test="tenantId != null">#{tenantId},</if>
|
<if test="tenantName != null">#{tenantName},</if>
|
<if test="phonenumber != null">#{phonenumber},</if>
|
<if test="perms != null">#{perms},</if>
|
<if test="delFlag != null">#{delFlag},</if>
|
<if test="createBy != null">#{createBy},</if>
|
<if test="createTime != null">#{createTime},</if>
|
<if test="updateBy != null">#{updateBy},</if>
|
<if test="updateTime != null">#{updateTime},</if>
|
<if test="remark != null">#{remark},</if>
|
</trim>
|
</insert>
|
|
<insert id="insertDeviceUserList" parameterType="java.util.ArrayList">
|
insert into iot_device_user
|
(device_id, user_id, device_name, user_name, is_owner,tenant_id,tenant_name,phonenumber,perms, create_time) values
|
<foreach collection="list" item="item" index="index" separator=",">
|
(#{item.deviceId},#{item.userId},#{item.deviceName}, #{item.userName}, #{item.isOwner}, #{item.tenantId},#{item.tenantName},#{item.phonenumber},#{item.perms}, #{item.createTime})
|
</foreach>
|
</insert>
|
|
<update id="updateDeviceUser" parameterType="com.fastbee.iot.domain.DeviceUser">
|
update iot_device_user
|
<trim prefix="SET" suffixOverrides=",">
|
<if test="userId != null">user_id = #{userId},</if>
|
<if test="deviceName != null and deviceName != ''">device_name = #{deviceName},</if>
|
<if test="userName != null and userName != ''">user_name = #{userName},</if>
|
<if test="isOwner != null">is_owner = #{isOwner},</if>
|
<if test="tenantId != null">tenant_id = #{tenantId},</if>
|
<if test="tenantName != null">tenant_name = #{tenantName},</if>
|
<if test="phonenumber != null">phonenumber = #{phonenumber},</if>
|
<if test="perms != null">perms = #{perms},</if>
|
<if test="delFlag != null">del_flag = #{delFlag},</if>
|
<if test="createBy != null">create_by = #{createBy},</if>
|
<if test="createTime != null">create_time = #{createTime},</if>
|
<if test="updateBy != null">update_by = #{updateBy},</if>
|
<if test="updateTime != null">update_time = #{updateTime},</if>
|
<if test="remark != null">remark = #{remark},</if>
|
</trim>
|
where device_id = #{deviceId} and user_id = #{userId}
|
</update>
|
|
<delete id="deleteDeviceUserByDeviceId" parameterType="com.fastbee.iot.model.UserIdDeviceIdModel">
|
delete from iot_device_user
|
<where>
|
<if test="1==1"> and device_id = #{deviceId}</if>
|
<if test="userId != null"> and user_id = #{userId}</if>
|
</where>
|
</delete>
|
|
<delete id="deleteDeviceUserByDeviceIds" parameterType="String">
|
delete from iot_device_user where device_id in
|
<foreach item="deviceId" collection="array" open="(" separator="," close=")">
|
#{deviceId}
|
</foreach>
|
</delete>
|
<delete id="deleteDeviceUser">
|
delete from iot_device_user where device_id = #{deviceId} and is_owner !=1 and user_id = #{userId}
|
</delete>
|
</mapper>
|