leutu
2024-06-03 3ef35e6cd16bbfa206b26bb3271eac40ad020bcb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
<?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>