liusuyi
2024-08-08 57c673aa3e83677bcf5d30b4b45d06bae6609db8
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
<?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.ruoyi.app.position.mapper.ArdAppPositionMapper">
    <resultMap type="ArdAppPosition" id="ArdAppPositionResult">
        <result property="id" column="id"/>
        <result property="userId" column="user_id"/>
        <result property="longitude" column="longitude"/>
        <result property="latitude" column="latitude"/>
        <result property="altitude" column="altitude"/>
        <result property="speed" column="speed"/>
        <result property="bearing" column="bearing"/>
        <result property="createTime" column="create_time"/>
    </resultMap>
 
    <sql id="selectArdAppPositionVo">
        select id, user_id, longitude, latitude, altitude,speed, bearing, create_time
        from ard_app_position
    </sql>
 
    <select id="selectArdAppPositionList" parameterType="ArdAppPosition" resultMap="ArdAppPositionResult">
        <include refid="selectArdAppPositionVo"/>
        <where>
        </where>
    </select>
 
    <select id="selectArdAppPositionById" parameterType="String" resultMap="ArdAppPositionResult">
        <include refid="selectArdAppPositionVo"/>
        where id = #{id}
    </select>
    <select id="selectLastArdAppPositionByUserId" parameterType="String" resultMap="ArdAppPositionResult">
        <include refid="selectArdAppPositionVo"/>
        where user_id = #{userId}
        order by create_time desc
        limit 1
    </select>
    <insert id="insertArdAppPosition" parameterType="ArdAppPosition">
        insert into ard_app_position
        <trim prefix="(" suffix=")" suffixOverrides=",">
            <if test="id != null">id,</if>
            <if test="userId != null">user_id,</if>
            <if test="longitude != null">longitude,</if>
            <if test="latitude != null">latitude,</if>
            <if test="altitude != null">altitude,</if>
            <if test="speed != null">speed,</if>
            <if test="bearing != null">bearing,</if>
            <if test="createTime != null">create_time,</if>
        </trim>
        <trim prefix="values (" suffix=")" suffixOverrides=",">
            <if test="id != null">#{id},</if>
            <if test="userId != null">#{userId},</if>
            <if test="longitude != null">#{longitude},</if>
            <if test="latitude != null">#{latitude},</if>
            <if test="altitude != null">#{altitude},</if>
            <if test="speed != null">#{speed},</if>
            <if test="bearing != null">#{bearing},</if>
            <if test="createTime != null">#{createTime},</if>
        </trim>
    </insert>
 
    <update id="updateArdAppPosition" parameterType="ArdAppPosition">
        update ard_app_position
        <trim prefix="SET" suffixOverrides=",">
            <if test="userId != null">user_id = #{userId},</if>
            <if test="longitude != null">longitude = #{longitude},</if>
            <if test="latitude != null">latitude = #{latitude},</if>
            <if test="altitude != null">altitude = #{altitude},</if>
            <if test="speed != null">speed = #{speed},</if>
            <if test="bearing != null">bearing = #{bearing},</if>
            <if test="createTime != null">create_time = #{createTime},</if>
        </trim>
        where id = #{id}
    </update>
 
    <delete id="deleteArdAppPositionById" parameterType="String">
        delete
        from ard_app_position
        where id = #{id}
    </delete>
 
    <delete id="deleteArdAppPositionByIds" parameterType="String">
        delete from ard_app_position where id in
        <foreach item="id" collection="array" open="(" separator="," close=")">
            #{id}
        </foreach>
    </delete>
 
    <select id="getOnlineCommanderPosition" parameterType="java.lang.String" resultType="java.util.Map">
        select su.user_name as "userName",su.nick_name as "nickName",
        aap.user_id as "userId",aap.longitude,aap.latitude,
        coalesce(cast(aap.altitude as varchar),'') as altitude,
        coalesce(cast(aap.speed as varchar),'') as speed,
        coalesce(cast(aap.bearing as varchar),'') as bearing,
        aap.create_time as "createTime"
        from ard_app_application aaa
        inner join sys_user su on aaa.commander_id = su.user_id
        inner join ard_app_position aap on su.user_id = aap.user_id
        where aaa.soilder_id = #{soilderId} and aaa.application_type = 'Commander'
        and aaa.state = '1' and su.app_online_state = '1'
        order by aap.create_time desc limit 1 offset 0
    </select>
 
    <select id="getAPPPositionByUserIdAndTime" parameterType="java.lang.String" resultMap="ArdAppPositionResult">
        select * from ard_app_position aap
        where aap.user_id = #{userId} and aap.create_time &gt;= #{beginTime}
        and aap.create_time &lt;= #{endTime} order by aap.create_time asc
    </select>
 
    <select id="getLastAPPPositionByUserId" parameterType="java.lang.String" resultMap="ArdAppPositionResult">
        select * from ard_app_position aap
        where aap.user_id = #{userId}
        order by aap.create_time desc limit 1 offset 0
    </select>
</mapper>