[add] 新增无人机模块后端项目

[refactor] 重构后端项目
This commit is contained in:
lcj
2025-05-21 11:30:59 +08:00
parent 4c238435d8
commit dc1de34116
1699 changed files with 54361 additions and 325 deletions

View File

@ -0,0 +1,71 @@
<?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.system.mapper.DroneMapper">
<resultMap type="Drone" id="DroneResult">
<result property="id" column="id" />
<result property="gateway" column="gateway" />
<result property="sn" column="sn" />
<result property="isOnline" column="is_online" />
</resultMap>
<sql id="selectDroneVo">
select id, gateway, sn, is_online from drone
</sql>
<select id="selectDroneList" parameterType="Drone" resultMap="DroneResult">
<include refid="selectDroneVo"/>
<where>
<if test="gateway != null and gateway != ''"> and gateway = #{gateway}</if>
<if test="sn != null and sn != ''"> and sn = #{sn}</if>
<if test="isOnline != null and isOnline != ''"> and is_online = #{isOnline}</if>
</where>
</select>
<select id="selectDroneById" parameterType="Long" resultMap="DroneResult">
<include refid="selectDroneVo"/>
where id = #{id}
</select>
<!-- 根据设备sn查询设备信息 -->
<select id="selectDroneBySn" resultType="com.ruoyi.system.domain.Drone">
select id, gateway, sn, is_online from drone where sn = #{sn}
</select>
<insert id="insertDrone" parameterType="Drone" useGeneratedKeys="true" keyProperty="id">
insert into drone
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="gateway != null">gateway,</if>
<if test="sn != null and sn != ''">sn,</if>
<if test="isOnline != null">is_online,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="gateway != null">#{gateway},</if>
<if test="sn != null and sn != ''">#{sn},</if>
<if test="isOnline != null">#{isOnline},</if>
</trim>
</insert>
<update id="updateDrone" parameterType="Drone">
update drone
<trim prefix="SET" suffixOverrides=",">
<if test="gateway != null">gateway = #{gateway},</if>
<if test="sn != null and sn != ''">sn = #{sn},</if>
<if test="isOnline != null">is_online = #{isOnline},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteDroneById" parameterType="Long">
delete from drone where id = #{id}
</delete>
<delete id="deleteDroneByIds" parameterType="String">
delete from drone where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,157 @@
<?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.system.mapper.DroneMissionsMapper">
<resultMap type="DroneMissions" id="DroneMissionsResult">
<result property="id" column="id"/>
<result property="missionName" column="mission_name"/>
<result property="flightPathUrl" column="flight_path_url"/>
<result property="flightPathMd5" column="flight_path_md5"/>
<result property="returnAltitude" column="return_altitude"/>
<result property="returnAltitudeMode" column="return_altitude_mode"/>
<result property="outOfControlAction" column="out_of_control_action"/>
<result property="flightControlAction" column="flight_control_action"/>
<result property="waylinePrecisionType" column="wayline_precision_type"/>
<result property="createdAt" column="created_at"/>
</resultMap>
<sql id="selectDroneMissionsVo">
select id,
mission_name,
flight_path_url,
flight_path_md5,
return_altitude,
return_altitude_mode,
out_of_control_action,
flight_control_action,
wayline_precision_type,
created_at
from drone_missions
</sql>
<select id="selectDroneMissionsList" parameterType="DroneMissions" resultMap="DroneMissionsResult">
<include refid="selectDroneMissionsVo"/>
<where>
<if test="missionName != null and missionName != ''">and mission_name like concat('%', #{missionName},
'%')
</if>
<if test="flightPathUrl != null and flightPathUrl != ''">and flight_path_url = #{flightPathUrl}</if>
<if test="flightPathMd5 != null and flightPathMd5 != ''">and flight_path_md5 = #{flightPathMd5}</if>
<if test="returnAltitude != null ">and return_altitude = #{returnAltitude}</if>
<if test="returnAltitudeMode != null ">and return_altitude_mode = #{returnAltitudeMode}</if>
<if test="outOfControlAction != null ">and out_of_control_action = #{outOfControlAction}</if>
<if test="flightControlAction != null ">and flight_control_action = #{flightControlAction}</if>
<if test="waylinePrecisionType != null ">and wayline_precision_type = #{waylinePrecisionType}</if>
<if test="createdAt != null ">and created_at = #{createdAt}</if>
</where>
</select>
<select id="selectDroneMissionsById" parameterType="Long" resultMap="DroneMissionsResult">
<include refid="selectDroneMissionsVo"/>
where id = #{id}
</select>
<!-- 查询条件 -->
<select id="selectDroneMissionsByCondition" resultMap="DroneMissionsResult">
select drone_missions.*
from drone_missions
join flight_paths on drone_missions.flight_path_md5 = flight_paths.file_md5
join flight_tasks on drone_missions.id = flight_tasks.messionId
where flight_tasks.flightId = #{flightId}
</select>
<select id="selectDroneMissionsVoList" resultType="com.ruoyi.system.dto.DroneMissionsVo">
select
drone_missions.id,
drone_missions.mission_name as missionName,
drone_missions.flight_path_url as flightPathUrl,
drone_missions.flight_path_md5 as flightPathUrl,
drone_missions.return_altitude as returnAltitude,
drone_missions.return_altitude_mode as returnAltitudeMode,
drone_missions.out_of_control_action as outOfControlAction,
drone_missions.flight_control_action as flightControlAction,
drone_missions.wayline_precision_type as waylinePrecisionType,
drone_missions.created_at as createdAt, flight_paths.file_name as waylineName
from drone_missions
join flight_paths on drone_missions.flight_path_md5 = flight_paths.file_md5
<where>
<if test="missionName != null and missionName != ''">and drone_missions.mission_name like concat('%',
#{missionName},
'%')
</if>
<if test="flightPathUrl != null and flightPathUrl != ''">and drone_missions.flight_path_url =
#{flightPathUrl}
</if>
<if test="flightPathMd5 != null and flightPathMd5 != ''">and drone_missions.flight_path_md5 =
#{flightPathMd5}
</if>
<if test="returnAltitude != null ">and drone_missions.return_altitude = #{returnAltitude}</if>
<if test="returnAltitudeMode != null ">and drone_missions.return_altitude_mode = #{returnAltitudeMode}</if>
<if test="outOfControlAction != null ">and drone_missions.out_of_control_action = #{outOfControlAction}</if>
<if test="flightControlAction != null ">and drone_missions.flight_control_action = #{flightControlAction}
</if>
<if test="waylinePrecisionType != null ">and drone_missions.wayline_precision_type =
#{waylinePrecisionType}
</if>
<if test="createdAt != null ">and drone_missions.created_at = #{createdAt}</if>
</where>
order by drone_missions.id desc
</select>
<insert id="insertDroneMissions" parameterType="DroneMissions" useGeneratedKeys="true" keyProperty="id">
insert into drone_missions
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="missionName != null and missionName != ''">mission_name,</if>
<if test="flightPathUrl != null and flightPathUrl != ''">flight_path_url,</if>
<if test="flightPathMd5 != null and flightPathMd5 != ''">flight_path_md5,</if>
<if test="returnAltitude != null">return_altitude,</if>
<if test="returnAltitudeMode != null">return_altitude_mode,</if>
<if test="outOfControlAction != null">out_of_control_action,</if>
<if test="flightControlAction != null">flight_control_action,</if>
<if test="waylinePrecisionType != null">wayline_precision_type,</if>
<if test="createdAt != null">created_at,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="missionName != null and missionName != ''">#{missionName},</if>
<if test="flightPathUrl != null and flightPathUrl != ''">#{flightPathUrl},</if>
<if test="flightPathMd5 != null and flightPathMd5 != ''">#{flightPathMd5},</if>
<if test="returnAltitude != null">#{returnAltitude},</if>
<if test="returnAltitudeMode != null">#{returnAltitudeMode},</if>
<if test="outOfControlAction != null">#{outOfControlAction},</if>
<if test="flightControlAction != null">#{flightControlAction},</if>
<if test="waylinePrecisionType != null">#{waylinePrecisionType},</if>
<if test="createdAt != null">#{createdAt},</if>
</trim>
</insert>
<update id="updateDroneMissions" parameterType="DroneMissions">
update drone_missions
<trim prefix="SET" suffixOverrides=",">
<if test="missionName != null and missionName != ''">mission_name = #{missionName},</if>
<if test="flightPathUrl != null and flightPathUrl != ''">flight_path_url = #{flightPathUrl},</if>
<if test="flightPathMd5 != null and flightPathMd5 != ''">flight_path_md5 = #{flightPathMd5},</if>
<if test="returnAltitude != null">return_altitude = #{returnAltitude},</if>
<if test="returnAltitudeMode != null">return_altitude_mode = #{returnAltitudeMode},</if>
<if test="outOfControlAction != null">out_of_control_action = #{outOfControlAction},</if>
<if test="flightControlAction != null">flight_control_action = #{flightControlAction},</if>
<if test="waylinePrecisionType != null">wayline_precision_type = #{waylinePrecisionType},</if>
<if test="createdAt != null">created_at = #{createdAt},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteDroneMissionsById" parameterType="Long">
delete
from drone_missions
where id = #{id}
</delete>
<delete id="deleteDroneMissionsByIds" parameterType="String">
delete from drone_missions where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,166 @@
<?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.system.mapper.FlightPathsMapper">
<resultMap type="FlightPaths" id="FlightPathsResult">
<result property="id" column="id"/>
<result property="fileName" column="file_name"/>
<result property="fileUrl" column="file_url"/>
<result property="fileMd5" column="file_md5"/>
<result property="photoNum" column="photo_num"/>
<result property="waylineLen" column="wayline_len"/>
<result property="flag" column="flag"/>
<result property="estimateTime" column="estimate_time"/>
<result property="createdAt" column="created_at"/>
<result property="updatedAt" column="updated_at"/>
<result property="type" column="type"/>
<result property="deviceType" column="device_type"/>
<result property="points" column="points"/>
<result property="isImport" column="is_import"/>
<result property="globalPointHeight" column="global_point_height"/>
</resultMap>
<sql id="selectFlightPathsVo">
select id,
file_name,
file_url,
file_md5,
photo_num,
wayline_len,
flag,
estimate_time,
created_at,
updated_at,
type,
device_type,
points,
is_import,
global_point_height
from flight_paths
</sql>
<select id="selectFlightPathsList" parameterType="FlightPaths" resultMap="FlightPathsResult">
<include refid="selectFlightPathsVo"/>
<where>
<if test="fileName != null and fileName != ''">and file_name like concat('%', #{fileName}, '%')</if>
<if test="fileUrl != null and fileUrl != ''">and file_url = #{fileUrl}</if>
<if test="fileMd5 != null and fileMd5 != ''">and file_md5 = #{fileMd5}</if>
<if test="photoNum != null ">and photo_num = #{photoNum}</if>
<if test="waylineLen != null and waylineLen != ''">and wayline_len = #{waylineLen}</if>
<if test="flag != null and flag != ''">and flag = #{flag}</if>
<if test="estimateTime != null and estimateTime != ''">and estimate_time = #{estimateTime}</if>
<if test="createdAt != null ">and created_at = #{createdAt}</if>
<if test="updatedAt != null ">and updated_at = #{updatedAt}</if>
<if test="type != null ">and type = #{type}</if>
<if test="deviceType != null">and device_type = #{deviceType}</if>
<if test="points != null and points != ''">and points = #{points}</if>
<if test="isImport != null and isImport != ''">and is_import = #{isImport}</if>
<if test="globalPointHeight != null">and global_point_height = #{globalPointHeight}</if>
</where>
order by
<choose>
<when test="order == 1">updated_at desc</when>
<otherwise>updated_at asc</otherwise>
</choose>
</select>
<select id="selectFlightPathsById" parameterType="Long" resultMap="FlightPathsResult">
<include refid="selectFlightPathsVo"/>
where id = #{id}
</select>
<select id="selectByCondition" resultType="com.ruoyi.system.domain.FlightPaths">
<include refid="selectFlightPathsVo"/>
<where>
<if test="fileName != null and fileName != ''">and file_name = #{fileName}</if>
<if test="fileUrl != null and fileUrl != ''">and file_url = #{fileUrl}</if>
<if test="fileMd5 != null and fileMd5 != ''">and file_md5 = #{fileMd5}</if>
<if test="photoNum != null ">and photo_num = #{photoNum}</if>
<if test="waylineLen != null and waylineLen != ''">and wayline_len = #{waylineLen}</if>
<if test="flag != null and flag != ''">and flag = #{flag}</if>
<if test="estimateTime != null and estimateTime != ''">and estimate_time = #{estimateTime}</if>
<if test="createdAt != null ">and created_at = #{createdAt}</if>
<if test="updatedAt != null ">and updated_at = #{updatedAt}</if>
<if test="type != null ">and type = #{type}</if>
<if test="deviceType != null">and device_type = #{deviceType}</if>
<if test="points != null and points != ''">and points = #{points}</if>
<if test="isImport != null and isImport != ''">and is_import = #{isImport}</if>
<if test="globalPointHeight != null">and global_point_height = #{globalPointHeight}</if>
</where>
order by
<choose>
<when test="order == 1">updated_at desc</when>
<otherwise>updated_at asc</otherwise>
</choose>
</select>
<insert id="insertFlightPaths" parameterType="FlightPaths" useGeneratedKeys="true" keyProperty="id">
insert into flight_paths
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="fileName != null and fileName != ''">file_name,</if>
<if test="fileUrl != null and fileUrl != ''">file_url,</if>
<if test="fileMd5 != null and fileMd5 != ''">file_md5,</if>
<if test="photoNum != null">photo_num,</if>
<if test="waylineLen != null">wayline_len,</if>
<if test="flag != null">flag,</if>
<if test="estimateTime != null">estimate_time,</if>
<if test="createdAt != null">created_at,</if>
<if test="updatedAt != null">updated_at,</if>
<if test="type != null">type,</if>
<if test="deviceType != null">device_type,</if>
<if test="points != null">points,</if>
<if test="isImport != null">is_import,</if>
<if test="globalPointHeight != null">global_point_height,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="fileName != null and fileName != ''">#{fileName},</if>
<if test="fileUrl != null and fileUrl != ''">#{fileUrl},</if>
<if test="fileMd5 != null and fileMd5 != ''">#{fileMd5},</if>
<if test="photoNum != null">#{photoNum},</if>
<if test="waylineLen != null">#{waylineLen},</if>
<if test="flag != null">#{flag},</if>
<if test="estimateTime != null">#{estimateTime},</if>
<if test="createdAt != null">#{createdAt},</if>
<if test="updatedAt != null">#{updatedAt},</if>
<if test="type != null">#{type},</if>
<if test="deviceType != null">#{deviceType},</if>
<if test="points != null">#{points},</if>
<if test="isImport != null">#{isImport},</if>
<if test="globalPointHeight != null">#{globalPointHeight},</if>
</trim>
</insert>
<update id="updateFlightPaths" parameterType="FlightPaths">
update flight_paths
<trim prefix="SET" suffixOverrides=",">
<if test="fileName != null and fileName != ''">file_name = #{fileName},</if>
<if test="fileUrl != null and fileUrl != ''">file_url = #{fileUrl},</if>
<if test="fileMd5 != null and fileMd5 != ''">file_md5 = #{fileMd5},</if>
<if test="photoNum != null">photo_num = #{photoNum},</if>
<if test="waylineLen != null">wayline_len = #{waylineLen},</if>
<if test="flag != null">flag = #{flag},</if>
<if test="estimateTime != null">estimate_time = #{estimateTime},</if>
<if test="createdAt != null">created_at = #{createdAt},</if>
<if test="updatedAt != null">updated_at = #{updatedAt},</if>
<if test="type != null">type = #{type},</if>
<if test="deviceType != null">device_type = #{deviceType},</if>
<if test="points != null">points = #{points},</if>
<if test="isImport != null">is_import = #{isImport},</if>
<if test="globalPointHeight != null">global_point_height = #{globalPointHeight},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteFlightPathsById" parameterType="Long">
delete from flight_paths where id = #{id}
</delete>
<delete id="deleteFlightPathsByIds" parameterType="String">
delete from flight_paths where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,132 @@
<?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.system.mapper.FlightTasksMapper">
<resultMap type="FlightTasks" id="FlightTasksResult">
<result property="id" column="id" />
<result property="sn" column="sn" />
<result property="isExecuted" column="is_executed" />
<result property="status" column="status" />
<result property="messionId" column="messionId" />
<result property="flightId" column="flightId" />
<result property="realPhotoNum" column="real_photo_num" />
<result property="createdAt" column="created_at" />
<result property="completeAt" column="complete_at" />
</resultMap>
<sql id="selectFlightTasksVo">
select id, sn, is_executed, status, messionId, flightId, real_photo_num, created_at, complete_at from flight_tasks
</sql>
<select id="selectFlightTasksList" parameterType="FlightTasks" resultMap="FlightTasksResult">
<include refid="selectFlightTasksVo"/>
<where>
<if test="sn != null and sn != ''"> and sn = #{sn}</if>
<if test="isExecuted != null "> and is_executed = #{isExecuted}</if>
<if test="status != null and status != ''"> and status = #{status}</if>
<if test="messionId != null "> and messionId = #{messionId}</if>
<if test="flightId != null and flightId != ''"> and flightId = #{flightId}</if>
<if test="realPhotoNum != null "> and real_photo_num = #{realPhotoNum}</if>
<if test="createdAt != null "> and created_at = #{createdAt}</if>
<if test="completeAt != null "> and complete_at = #{completeAt}</if>
</where>
</select>
<select id="selectFlightTasksById" parameterType="Long" resultMap="FlightTasksResult">
<include refid="selectFlightTasksVo"/>
where id = #{id}
</select>
<!-- 查询任务列表 -->
<select id="selectFlightTasksVoList" resultType="com.ruoyi.system.dto.FlightTasksVo">
select flight_tasks.id,
flight_tasks.sn,
flight_tasks.is_executed as isExecuted,
flight_tasks.status,
flight_tasks.messionId,
flight_tasks.flightId,
flight_tasks.real_photo_num as realPhotoNum,
flight_tasks.created_at as createdAt,
flight_tasks.complete_at as completeAt,
drone_missions.mission_name as missionName,
flight_paths.photo_num as photoNum,
flight_paths.wayline_len as waylineLen,
flight_paths.type as waylineType,
flight_paths.file_name as waylineName
from flight_tasks
join drone_missions on flight_tasks.messionId = drone_missions.id
join flight_paths on drone_missions.flight_path_md5 = flight_paths.file_md5
<where>
<if test="sn != null and sn != ''">and flight_tasks.sn = #{sn}</if>
<if test="isExecuted != null ">and flight_tasks.is_executed = #{isExecuted}</if>
<if test="status != null and status != ''">and flight_tasks.status = #{status}</if>
<if test="messionId != null ">and flight_tasks.messionId = #{messionId}</if>
<if test="flightId != null and flightId != ''">and flight_tasks.flightId = #{flightId}</if>
<if test="realPhotoNum != null ">and flight_tasks.real_photo_num = #{realPhotoNum}</if>
<if test="createdAt != null ">and flight_tasks.created_at = #{createdAt}</if>
<if test="completeAt != null ">and flight_tasks.complete_at = #{completeAt}</if>
</where>
order by flight_tasks.id desc
</select>
<insert id="insertFlightTasks" parameterType="FlightTasks" useGeneratedKeys="true" keyProperty="id">
insert into flight_tasks
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="sn != null and sn != ''">sn,</if>
<if test="isExecuted != null">is_executed,</if>
<if test="status != null and status != ''">status,</if>
<if test="messionId != null">messionId,</if>
<if test="flightId != null">flightId,</if>
<if test="realPhotoNum != null">real_photo_num,</if>
<if test="createdAt != null">created_at,</if>
<if test="completeAt != null">complete_at,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="sn != null and sn != ''">#{sn},</if>
<if test="isExecuted != null">#{isExecuted},</if>
<if test="status != null and status != ''">#{status},</if>
<if test="messionId != null">#{messionId},</if>
<if test="flightId != null">#{flightId},</if>
<if test="realPhotoNum != null">#{realPhotoNum},</if>
<if test="createdAt != null">#{createdAt},</if>
<if test="completeAt != null">#{completeAt},</if>
</trim>
</insert>
<update id="updateFlightTasks" parameterType="FlightTasks">
update flight_tasks
<trim prefix="SET" suffixOverrides=",">
<if test="sn != null and sn != ''">sn = #{sn},</if>
<if test="isExecuted != null">is_executed = #{isExecuted},</if>
<if test="status != null and status != ''">status = #{status},</if>
<if test="messionId != null">messionId = #{messionId},</if>
<if test="flightId != null">flightId = #{flightId},</if>
<if test="realPhotoNum != null">real_photo_num = #{realPhotoNum},</if>
<if test="createdAt != null">created_at = #{createdAt},</if>
<if test="completeAt != null">complete_at = #{completeAt},</if>
</trim>
where id = #{id}
</update>
<update id="updateFlightTasksStatus">
update flight_tasks
<trim prefix="SET" suffixOverrides=",">
<if test="status != null and status != ''">status = #{status},</if>
<if test="updateTime != null">complete_at = #{updateTime},</if>
</trim>
where flightId = #{flightId}
</update>
<delete id="deleteFlightTasksById" parameterType="Long">
delete from flight_tasks where id = #{id}
</delete>
<delete id="deleteFlightTasksByIds" parameterType="String">
delete from flight_tasks where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,86 @@
<?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.system.mapper.GatewayOperationLogMapper">
<resultMap type="GatewayOperationLog" id="GatewayOperationLogResult">
<result property="id" column="id" />
<result property="gatewayId" column="gateway_id" />
<result property="operationCommand" column="operation_command" />
<result property="sendParams" column="send_params" />
<result property="executionResponse" column="execution_response" />
<result property="executionResult" column="execution_result" />
<result property="operationTime" column="operation_time" />
</resultMap>
<sql id="selectGatewayOperationLogVo">
select id, gateway_id, operation_command, send_params, execution_response, execution_result, operation_time from gateway_operation_log
</sql>
<select id="selectGatewayOperationLogList" parameterType="GatewayOperationLog" resultMap="GatewayOperationLogResult">
<include refid="selectGatewayOperationLogVo"/>
<where>
<if test="gatewayId != null and gatewayId != ''">and gateway_id = #{gatewayId}</if>
<if test="operationCommand != null and operationCommand != ''">and operation_command =
#{operationCommand}
</if>
<if test="sendParams != null and sendParams != ''">and send_params = #{sendParams}</if>
<if test="executionResponse != null and executionResponse != ''">and execution_response =
#{executionResponse}
</if>
<if test="executionResult != null and executionResult != ''">and execution_result = #{executionResult}</if>
<if test="operationTime != null ">and operation_time = #{operationTime}</if>
</where>
order by operation_time desc
</select>
<select id="selectGatewayOperationLogById" parameterType="Long" resultMap="GatewayOperationLogResult">
<include refid="selectGatewayOperationLogVo"/>
where id = #{id}
</select>
<insert id="insertGatewayOperationLog" parameterType="GatewayOperationLog" useGeneratedKeys="true" keyProperty="id">
insert into gateway_operation_log
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="gatewayId != null and gatewayId != ''">gateway_id,</if>
<if test="operationCommand != null and operationCommand != ''">operation_command,</if>
<if test="sendParams != null">send_params,</if>
<if test="executionResponse != null">execution_response,</if>
<if test="executionResult != null">execution_result,</if>
<if test="operationTime != null">operation_time,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="gatewayId != null and gatewayId != ''">#{gatewayId},</if>
<if test="operationCommand != null and operationCommand != ''">#{operationCommand},</if>
<if test="sendParams != null">#{sendParams},</if>
<if test="executionResponse != null">#{executionResponse},</if>
<if test="executionResult != null">#{executionResult},</if>
<if test="operationTime != null">#{operationTime},</if>
</trim>
</insert>
<update id="updateGatewayOperationLog" parameterType="GatewayOperationLog">
update gateway_operation_log
<trim prefix="SET" suffixOverrides=",">
<if test="gatewayId != null and gatewayId != ''">gateway_id = #{gatewayId},</if>
<if test="operationCommand != null and operationCommand != ''">operation_command = #{operationCommand},</if>
<if test="sendParams != null">send_params = #{sendParams},</if>
<if test="executionResponse != null">execution_response = #{executionResponse},</if>
<if test="executionResult != null">execution_result = #{executionResult},</if>
<if test="operationTime != null">operation_time = #{operationTime},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteGatewayOperationLogById" parameterType="Long">
delete from gateway_operation_log where id = #{id}
</delete>
<delete id="deleteGatewayOperationLogByIds" parameterType="String">
delete from gateway_operation_log where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,90 @@
<?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.system.mapper.ManageDeviceDictionaryMapper">
<resultMap type="ManageDeviceDictionary" id="ManageDeviceDictionaryResult">
<result property="id" column="id"/>
<result property="domain" column="domain"/>
<result property="deviceType" column="device_type"/>
<result property="subType" column="sub_type"/>
<result property="deviceName" column="device_name"/>
<result property="deviceDesc" column="device_desc"/>
</resultMap>
<sql id="selectManageDeviceDictionaryVo">
select id, domain, device_type, sub_type, device_name, device_desc
from manage_device_dictionary
</sql>
<select id="selectManageDeviceDictionaryList" parameterType="ManageDeviceDictionary"
resultMap="ManageDeviceDictionaryResult">
<include refid="selectManageDeviceDictionaryVo"/>
<where>
<if test="domain != null ">and domain = #{domain}</if>
<if test="deviceType != null ">and device_type = #{deviceType}</if>
<if test="subType != null ">and sub_type = #{subType}</if>
<if test="deviceName != null and deviceName != ''">and device_name like concat('%', #{deviceName}, '%')
</if>
<if test="deviceDesc != null and deviceDesc != ''">and device_desc = #{deviceDesc}</if>
</where>
</select>
<select id="selectManageDeviceDictionaryById" parameterType="Integer" resultMap="ManageDeviceDictionaryResult">
<include refid="selectManageDeviceDictionaryVo"/>
where id = #{id}
</select>
<select id="selectManageDeviceDictionaryByCondition" resultMap="ManageDeviceDictionaryResult">
select *
from manage_device_dictionary
where domain = #{domain}
and device_type = #{deviceType}
and sub_type = #{subType}
</select>
<insert id="insertManageDeviceDictionary" parameterType="ManageDeviceDictionary" useGeneratedKeys="true"
keyProperty="id">
insert into manage_device_dictionary
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="domain != null">domain,</if>
<if test="deviceType != null">device_type,</if>
<if test="subType != null">sub_type,</if>
<if test="deviceName != null and deviceName != ''">device_name,</if>
<if test="deviceDesc != null">device_desc,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="domain != null">#{domain},</if>
<if test="deviceType != null">#{deviceType},</if>
<if test="subType != null">#{subType},</if>
<if test="deviceName != null and deviceName != ''">#{deviceName},</if>
<if test="deviceDesc != null">#{deviceDesc},</if>
</trim>
</insert>
<update id="updateManageDeviceDictionary" parameterType="ManageDeviceDictionary">
update manage_device_dictionary
<trim prefix="SET" suffixOverrides=",">
<if test="domain != null">domain = #{domain},</if>
<if test="deviceType != null">device_type = #{deviceType},</if>
<if test="subType != null">sub_type = #{subType},</if>
<if test="deviceName != null and deviceName != ''">device_name = #{deviceName},</if>
<if test="deviceDesc != null">device_desc = #{deviceDesc},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteManageDeviceDictionaryById" parameterType="Integer">
delete
from manage_device_dictionary
where id = #{id}
</delete>
<delete id="deleteManageDeviceDictionaryByIds" parameterType="String">
delete from manage_device_dictionary where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,77 @@
<?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.system.mapper.MinioFileMapper">
<resultMap type="MinioFile" id="MinioFileResult">
<result property="id" column="id" />
<result property="flightId" column="flightId" />
<result property="url" column="url" />
<result property="filename" column="filename" />
<result property="createdAt" column="created_at" />
</resultMap>
<sql id="selectMinioFileVo">
select id, flightId, url, filename, created_at from minio_file
</sql>
<select id="selectMinioFileList" parameterType="MinioFile" resultMap="MinioFileResult">
<include refid="selectMinioFileVo"/>
<where>
<if test="flightId != null "> and flightId = #{flightId}</if>
<if test="url != null and url != ''"> and url = #{url}</if>
<if test="filename != null and filename != ''"> and filename like concat('%', #{filename}, '%')</if>
<if test="createdAt != null "> and created_at = #{createdAt}</if>
</where>
</select>
<select id="selectMinioFileById" parameterType="Long" resultMap="MinioFileResult">
<include refid="selectMinioFileVo"/>
where id = #{id}
</select>
<select id="selectMinioFileName" resultMap="MinioFileResult">
select * from minio_file where filename = #{fileName}
</select>
<insert id="insertMinioFile" parameterType="MinioFile">
insert into minio_file
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="id != null">id,</if>
<if test="flightId != null">flightId,</if>
<if test="url != null">url,</if>
<if test="filename != null">filename,</if>
<if test="createdAt != null">created_at,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="id != null">#{id},</if>
<if test="flightId != null">#{flightId},</if>
<if test="url != null">#{url},</if>
<if test="filename != null">#{filename},</if>
<if test="createdAt != null">#{createdAt},</if>
</trim>
</insert>
<update id="updateMinioFile" parameterType="MinioFile">
update minio_file
<trim prefix="SET" suffixOverrides=",">
<if test="flightId != null">flightId = #{flightId},</if>
<if test="url != null">url = #{url},</if>
<if test="filename != null">filename = #{filename},</if>
<if test="createdAt != null">created_at = #{createdAt},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteMinioFileById" parameterType="Long">
delete from minio_file where id = #{id}
</delete>
<delete id="deleteMinioFileByIds" parameterType="String">
delete from minio_file where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,244 @@
<?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.system.mapper.MissionsMapper">
<resultMap type="Missions" id="MissionsResult">
<result property="id" column="id"/>
<result property="missionName" column="mission_name"/>
<result property="fileId" column="file_id"/>
<result property="returnAltitude" column="return_altitude"/>
<result property="returnAltitudeMode" column="return_altitude_mode"/>
<result property="outOfControlAction" column="out_of_control_action"/>
<result property="flightControlAction" column="flight_control_action"/>
<result property="waylinePrecisionType" column="wayline_precision_type"/>
<result property="createdAt" column="created_at"/>
<result property="type" column="type"/>
<result property="execTime" column="exec_time"/>
<result property="flightId" column="flightId"/>
<result property="state" column="state"/>
<result property="gateway" column="gateway"/>
<result property="timer" column="timer"/>
<result property="flag" column="flag"/>
<result property="lastTime" column="last_time"/>
</resultMap>
<sql id="selectMissionsVo">
select id,
mission_name,
file_id,
return_altitude,
return_altitude_mode,
out_of_control_action,
flight_control_action,
wayline_precision_type,
created_at,
type,
exec_time,
flightId,
state,
gateway,
timer,
flag,
last_time
from missions
</sql>
<select id="selectMissionsList" parameterType="Missions" resultMap="MissionsResult">
<include refid="selectMissionsVo"/>
<where>
<if test="missionName != null and missionName != ''">and mission_name like concat('%', #{missionName},
'%')
</if>
<if test="fileId != null and fileId != ''">and file_id = #{fileId}</if>
<if test="returnAltitude != null ">and return_altitude = #{returnAltitude}</if>
<if test="returnAltitudeMode != null ">and return_altitude_mode = #{returnAltitudeMode}</if>
<if test="outOfControlAction != null ">and out_of_control_action = #{outOfControlAction}</if>
<if test="flightControlAction != null ">and flight_control_action = #{flightControlAction}</if>
<if test="waylinePrecisionType != null ">and wayline_precision_type = #{waylinePrecisionType}</if>
<if test="createdAt != null ">and created_at = #{createdAt}</if>
<if test="type != null ">and type = #{type}</if>
<if test="execTime != null ">and exec_time = #{execTime}</if>
<if test="flightId != null ">and flightId = #{flightId}</if>
<if test="state != null and state != ''">and state = #{state}</if>
<if test="gateway != null and gateway != ''">and gateway = #{gateway}</if>
<if test="timer != null ">and timer = #{timer}</if>
<if test="flag != null ">and flag = #{flag}</if>
<if test="lastTime != null ">and last_time = #{lastTime}</if>
</where>
</select>
<select id="selectMissionsById" parameterType="Long" resultMap="MissionsResult">
<include refid="selectMissionsVo"/>
where id = #{id}
</select>
<!-- 查询所有任务 -->
<select id="list" resultType="com.ruoyi.system.dto.MissionsDto">
select missions.id,
missions.mission_name as missionName,
missions.file_id as fileId,
missions.return_altitude as returnAltitude,
missions.return_altitude_mode as returnAltitudeMode,
missions.out_of_control_action as outOfControlAction,
missions.flight_control_action as flightControlAction,
missions.wayline_precision_type as waylinePrecisionType,
missions.created_at as createdAt,
missions.type,
missions.exec_time as execTime,
missions.flightId,
missions.state,
missions.gateway,
missions.timer,
missions.flag,
missions.last_time as lastTime,
video_info.business_name as deviceName,
flight_paths.file_name as fileName,
flight_paths.points as points
from missions
join video_info on video_info.sn = #{gateway}
join flight_paths on flight_paths.id = missions.file_id
<!-- 条件查询:任务类型 -->
<if test="type != null and type != ''">
AND missions.type = #{type}
</if>
<!-- 网关筛选 -->
<if test="gateway != null and gateway != ''">
AND missions.gateway = #{gateway}
</if>
<!-- 条件查询:状态 -->
<if test="state != null and state != '' and state != '全部'">
AND missions.state = #{state}
</if>
<!-- 时间范围查询created_at -->
<if test="startTime != null">
AND missions.created_at &gt; #{startTime}
</if>
<if test="endTime != null">
AND missions.created_at &lt; #{endTime}
</if>
<!-- 模糊查询设备名称deviceName或文件名fileName -->
<if test="name != null and name != ''">
AND (missions.mission_name LIKE CONCAT('%', #{name}, '%')
OR flight_paths.file_name LIKE CONCAT('%', #{name}, '%'))
</if>
order by missions.created_at desc
</select>
<select id="getLatest" resultType="com.ruoyi.system.dto.MissionsDto">
select missions.id,
missions.mission_name as missionName,
missions.file_id as fileId,
missions.return_altitude as returnAltitude,
missions.return_altitude_mode as returnAltitudeMode,
missions.out_of_control_action as outOfControlAction,
missions.flight_control_action as flightControlAction,
missions.wayline_precision_type as waylinePrecisionType,
missions.created_at as createdAt,
missions.type,
missions.exec_time as execTime,
missions.flightId,
missions.state,
missions.gateway,
missions.timer,
missions.flag,
missions.last_time as lastTime,
video_info.business_name as deviceName,
flight_paths.file_name as fileName,
flight_paths.points as points
from missions
join video_info on video_info.sn = #{gateway}
join flight_paths on flight_paths.id = missions.file_id
WHERE missions.type = 1
AND missions.timer > NOW()
AND missions.gateway = #{gateway}
ORDER BY missions.timer asc LIMIT 1
</select>
<insert id="insertMissions" parameterType="Missions" useGeneratedKeys="true" keyProperty="id">
insert into missions
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="missionName != null and missionName != ''">mission_name,</if>
<if test="fileId != null and fileId != ''">file_id,</if>
<if test="returnAltitude != null">return_altitude,</if>
<if test="returnAltitudeMode != null">return_altitude_mode,</if>
<if test="outOfControlAction != null">out_of_control_action,</if>
<if test="flightControlAction != null">flight_control_action,</if>
<if test="waylinePrecisionType != null">wayline_precision_type,</if>
<if test="createdAt != null">created_at,</if>
<if test="type != null">type,</if>
<if test="execTime != null">exec_time,</if>
<if test="flightId != null">flightId,</if>
<if test="state != null">state,</if>
<if test="gateway != null">gateway,</if>
<if test="timer != null">timer,</if>
<if test="flag != null">flag,</if>
<if test="lastTime != null">last_time,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="missionName != null and missionName != ''">#{missionName},</if>
<if test="fileId != null and fileId != ''">#{fileId},</if>
<if test="returnAltitude != null">#{returnAltitude},</if>
<if test="returnAltitudeMode != null">#{returnAltitudeMode},</if>
<if test="outOfControlAction != null">#{outOfControlAction},</if>
<if test="flightControlAction != null">#{flightControlAction},</if>
<if test="waylinePrecisionType != null">#{waylinePrecisionType},</if>
<if test="createdAt != null">#{createdAt},</if>
<if test="type != null">#{type},</if>
<if test="execTime != null">#{execTime},</if>
<if test="flightId != null">#{flightId},</if>
<if test="state != null">#{state},</if>
<if test="gateway != null">#{gateway},</if>
<if test="timer != null">#{timer},</if>
<if test="flag != null">#{flag},</if>
<if test="lastTime != null">#{lastTime},</if>
</trim>
</insert>
<update id="updateMissions" parameterType="Missions">
update missions
<trim prefix="SET" suffixOverrides=",">
<if test="missionName != null and missionName != ''">mission_name = #{missionName},</if>
<if test="fileId != null and fileId != ''">file_id = #{fileId},</if>
<if test="returnAltitude != null">return_altitude = #{returnAltitude},</if>
<if test="returnAltitudeMode != null">return_altitude_mode = #{returnAltitudeMode},</if>
<if test="outOfControlAction != null">out_of_control_action = #{outOfControlAction},</if>
<if test="flightControlAction != null">flight_control_action = #{flightControlAction},</if>
<if test="waylinePrecisionType != null">wayline_precision_type = #{waylinePrecisionType},</if>
<if test="createdAt != null">created_at = #{createdAt},</if>
<if test="type != null">type = #{type},</if>
<if test="execTime != null">exec_time = #{execTime},</if>
<if test="flightId != null">flightId = #{flightId},</if>
<if test="state != null">state = #{state},</if>
<if test="gateway != null">gateway = #{gateway},</if>
<if test="timer != null">timer = #{timer},</if>
<if test="flag != null">flag = #{flag},</if>
<if test="lastTime != null">last_time = #{lastTime},</if>
</trim>
where id = #{id}
</update>
<!-- 设置 state 和 last_date -->
<update id="updateMissionsByFlightId">
update missions
set state = #{state},
last_time = #{lastTime}
where flightId = #{flightId}
</update>
<delete id="deleteMissionsById" parameterType="Long">
delete
from missions
where id = #{id}
</delete>
<delete id="deleteMissionsByIds" parameterType="String">
delete from missions where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,66 @@
<?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.system.mapper.OneClickTakeoffMapper">
<resultMap type="OneClickTakeoff" id="OneClickTakeoffResult">
<result property="id" column="id" />
<result property="droneSerialNumber" column="drone_serial_number" />
<result property="takeoffTime" column="takeoff_time" />
<result property="flightId" column="flight_id" />
</resultMap>
<sql id="selectOneClickTakeoffVo">
select id, drone_serial_number, takeoff_time, flight_id from one_click_takeoff
</sql>
<select id="selectOneClickTakeoffList" parameterType="OneClickTakeoff" resultMap="OneClickTakeoffResult">
<include refid="selectOneClickTakeoffVo"/>
<where>
<if test="droneSerialNumber != null and droneSerialNumber != ''"> and drone_serial_number = #{droneSerialNumber}</if>
<if test="takeoffTime != null "> and takeoff_time = #{takeoffTime}</if>
<if test="flightId != null "> and flight_id = #{flightId}</if>
</where>
</select>
<select id="selectOneClickTakeoffById" parameterType="Long" resultMap="OneClickTakeoffResult">
<include refid="selectOneClickTakeoffVo"/>
where id = #{id}
</select>
<insert id="insertOneClickTakeoff" parameterType="OneClickTakeoff" useGeneratedKeys="true" keyProperty="id">
insert into one_click_takeoff
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="droneSerialNumber != null and droneSerialNumber != ''">drone_serial_number,</if>
<if test="takeoffTime != null">takeoff_time,</if>
<if test="flightId != null">flight_id,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="droneSerialNumber != null and droneSerialNumber != ''">#{droneSerialNumber},</if>
<if test="takeoffTime != null">#{takeoffTime},</if>
<if test="flightId != null">#{flightId},</if>
</trim>
</insert>
<update id="updateOneClickTakeoff" parameterType="OneClickTakeoff">
update one_click_takeoff
<trim prefix="SET" suffixOverrides=",">
<if test="droneSerialNumber != null and droneSerialNumber != ''">drone_serial_number = #{droneSerialNumber},</if>
<if test="takeoffTime != null">takeoff_time = #{takeoffTime},</if>
<if test="flightId != null">flight_id = #{flightId},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteOneClickTakeoffById" parameterType="Long">
delete from one_click_takeoff where id = #{id}
</delete>
<delete id="deleteOneClickTakeoffByIds" parameterType="String">
delete from one_click_takeoff where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,93 @@
<?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.system.mapper.ScheduleTaskMapper">
<resultMap type="ScheduleTask" id="ScheduleTaskResult">
<result property="id" column="id" />
<result property="sn" column="sn" />
<result property="taskId" column="taskId" />
<result property="execMonth" column="exec_month" />
<result property="execDay" column="exec_day" />
<result property="execHour" column="exec_hour" />
<result property="execMinute" column="exec_minute" />
<result property="execSecond" column="exec_second" />
<result property="createdAt" column="created_at" />
</resultMap>
<sql id="selectScheduleTaskVo">
select id, sn, taskId, exec_month, exec_day, exec_hour, exec_minute, exec_second, created_at from schedule_task
</sql>
<select id="selectScheduleTaskList" parameterType="ScheduleTask" resultMap="ScheduleTaskResult">
<include refid="selectScheduleTaskVo"/>
<where>
<if test="sn != null and sn != ''"> and sn = #{sn}</if>
<if test="taskId != null and taskId != ''"> and taskId = #{taskId}</if>
<if test="execMonth != null and execMonth != ''"> and exec_month = #{execMonth}</if>
<if test="execDay != null and execDay != ''"> and exec_day = #{execDay}</if>
<if test="execHour != null and execHour != ''"> and exec_hour = #{execHour}</if>
<if test="execMinute != null and execMinute != ''"> and exec_minute = #{execMinute}</if>
<if test="execSecond != null and execSecond != ''"> and exec_second = #{execSecond}</if>
<if test="createdAt != null "> and created_at = #{createdAt}</if>
</where>
</select>
<select id="selectScheduleTaskById" parameterType="Long" resultMap="ScheduleTaskResult">
<include refid="selectScheduleTaskVo"/>
where id = #{id}
</select>
<insert id="insertScheduleTask" parameterType="ScheduleTask">
insert into schedule_task
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="id != null">id,</if>
<if test="sn != null and sn != ''">sn,</if>
<if test="taskId != null and taskId != ''">taskId,</if>
<if test="execMonth != null and execMonth != ''">exec_month,</if>
<if test="execDay != null and execDay != ''">exec_day,</if>
<if test="execHour != null and execHour != ''">exec_hour,</if>
<if test="execMinute != null and execMinute != ''">exec_minute,</if>
<if test="execSecond != null and execSecond != ''">exec_second,</if>
<if test="createdAt != null">created_at,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="id != null">#{id},</if>
<if test="sn != null and sn != ''">#{sn},</if>
<if test="taskId != null and taskId != ''">#{taskId},</if>
<if test="execMonth != null and execMonth != ''">#{execMonth},</if>
<if test="execDay != null and execDay != ''">#{execDay},</if>
<if test="execHour != null and execHour != ''">#{execHour},</if>
<if test="execMinute != null and execMinute != ''">#{execMinute},</if>
<if test="execSecond != null and execSecond != ''">#{execSecond},</if>
<if test="createdAt != null">#{createdAt},</if>
</trim>
</insert>
<update id="updateScheduleTask" parameterType="ScheduleTask">
update schedule_task
<trim prefix="SET" suffixOverrides=",">
<if test="sn != null and sn != ''">sn = #{sn},</if>
<if test="taskId != null and taskId != ''">taskId = #{taskId},</if>
<if test="execMonth != null and execMonth != ''">exec_month = #{execMonth},</if>
<if test="execDay != null and execDay != ''">exec_day = #{execDay},</if>
<if test="execHour != null and execHour != ''">exec_hour = #{execHour},</if>
<if test="execMinute != null and execMinute != ''">exec_minute = #{execMinute},</if>
<if test="execSecond != null and execSecond != ''">exec_second = #{execSecond},</if>
<if test="createdAt != null">created_at = #{createdAt},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteScheduleTaskById" parameterType="Long">
delete from schedule_task where id = #{id}
</delete>
<delete id="deleteScheduleTaskByIds" parameterType="String">
delete from schedule_task where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,117 @@
<?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.system.mapper.SysConfigMapper">
<resultMap type="SysConfig" id="SysConfigResult">
<id property="configId" column="config_id" />
<result property="configName" column="config_name" />
<result property="configKey" column="config_key" />
<result property="configValue" column="config_value" />
<result property="configType" column="config_type" />
<result property="createBy" column="create_by" />
<result property="createTime" column="create_time" />
<result property="updateBy" column="update_by" />
<result property="updateTime" column="update_time" />
</resultMap>
<sql id="selectConfigVo">
select config_id, config_name, config_key, config_value, config_type, create_by, create_time, update_by, update_time, remark
from sys_config
</sql>
<!-- 查询条件 -->
<sql id="sqlwhereSearch">
<where>
<if test="configId !=null">
and config_id = #{configId}
</if>
<if test="configKey !=null and configKey != ''">
and config_key = #{configKey}
</if>
</where>
</sql>
<select id="selectConfig" parameterType="SysConfig" resultMap="SysConfigResult">
<include refid="selectConfigVo"/>
<include refid="sqlwhereSearch"/>
</select>
<select id="selectConfigList" parameterType="SysConfig" resultMap="SysConfigResult">
<include refid="selectConfigVo"/>
<where>
<if test="configName != null and configName != ''">
AND config_name like concat('%', #{configName}, '%')
</if>
<if test="configType != null and configType != ''">
AND config_type = #{configType}
</if>
<if test="configKey != null and configKey != ''">
AND config_key like concat('%', #{configKey}, '%')
</if>
<if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 -->
and date_format(create_time,'%y%m%d') &gt;= date_format(#{params.beginTime},'%y%m%d')
</if>
<if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 -->
and date_format(create_time,'%y%m%d') &lt;= date_format(#{params.endTime},'%y%m%d')
</if>
</where>
</select>
<select id="selectConfigById" parameterType="Long" resultMap="SysConfigResult">
<include refid="selectConfigVo"/>
where config_id = #{configId}
</select>
<select id="checkConfigKeyUnique" parameterType="String" resultMap="SysConfigResult">
<include refid="selectConfigVo"/>
where config_key = #{configKey} limit 1
</select>
<insert id="insertConfig" parameterType="SysConfig">
insert into sys_config (
<if test="configName != null and configName != '' ">config_name,</if>
<if test="configKey != null and configKey != '' ">config_key,</if>
<if test="configValue != null and configValue != '' ">config_value,</if>
<if test="configType != null and configType != '' ">config_type,</if>
<if test="createBy != null and createBy != ''">create_by,</if>
<if test="remark != null and remark != ''">remark,</if>
create_time
)values(
<if test="configName != null and configName != ''">#{configName},</if>
<if test="configKey != null and configKey != ''">#{configKey},</if>
<if test="configValue != null and configValue != ''">#{configValue},</if>
<if test="configType != null and configType != ''">#{configType},</if>
<if test="createBy != null and createBy != ''">#{createBy},</if>
<if test="remark != null and remark != ''">#{remark},</if>
sysdate()
)
</insert>
<update id="updateConfig" parameterType="SysConfig">
update sys_config
<set>
<if test="configName != null and configName != ''">config_name = #{configName},</if>
<if test="configKey != null and configKey != ''">config_key = #{configKey},</if>
<if test="configValue != null and configValue != ''">config_value = #{configValue},</if>
<if test="configType != null and configType != ''">config_type = #{configType},</if>
<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if>
<if test="remark != null">remark = #{remark},</if>
update_time = sysdate()
</set>
where config_id = #{configId}
</update>
<delete id="deleteConfigById" parameterType="Long">
delete from sys_config where config_id = #{configId}
</delete>
<delete id="deleteConfigByIds" parameterType="Long">
delete from sys_config where config_id in
<foreach item="configId" collection="array" open="(" separator="," close=")">
#{configId}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,159 @@
<?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.system.mapper.SysDeptMapper">
<resultMap type="SysDept" id="SysDeptResult">
<id property="deptId" column="dept_id" />
<result property="parentId" column="parent_id" />
<result property="ancestors" column="ancestors" />
<result property="deptName" column="dept_name" />
<result property="orderNum" column="order_num" />
<result property="leader" column="leader" />
<result property="phone" column="phone" />
<result property="email" column="email" />
<result property="status" column="status" />
<result property="delFlag" column="del_flag" />
<result property="parentName" column="parent_name" />
<result property="createBy" column="create_by" />
<result property="createTime" column="create_time" />
<result property="updateBy" column="update_by" />
<result property="updateTime" column="update_time" />
</resultMap>
<sql id="selectDeptVo">
select d.dept_id, d.parent_id, d.ancestors, d.dept_name, d.order_num, d.leader, d.phone, d.email, d.status, d.del_flag, d.create_by, d.create_time
from sys_dept d
</sql>
<select id="selectDeptList" parameterType="SysDept" resultMap="SysDeptResult">
<include refid="selectDeptVo"/>
where d.del_flag = '0'
<if test="deptId != null and deptId != 0">
AND dept_id = #{deptId}
</if>
<if test="parentId != null and parentId != 0">
AND parent_id = #{parentId}
</if>
<if test="deptName != null and deptName != ''">
AND dept_name like concat('%', #{deptName}, '%')
</if>
<if test="status != null and status != ''">
AND status = #{status}
</if>
<!-- 数据范围过滤 -->
${params.dataScope}
order by d.parent_id, d.order_num
</select>
<select id="selectDeptListByRoleId" resultType="Long">
select d.dept_id
from sys_dept d
left join sys_role_dept rd on d.dept_id = rd.dept_id
where rd.role_id = #{roleId}
<if test="deptCheckStrictly">
and d.dept_id not in (select d.parent_id from sys_dept d inner join sys_role_dept rd on d.dept_id = rd.dept_id and rd.role_id = #{roleId})
</if>
order by d.parent_id, d.order_num
</select>
<select id="selectDeptById" parameterType="Long" resultMap="SysDeptResult">
select d.dept_id, d.parent_id, d.ancestors, d.dept_name, d.order_num, d.leader, d.phone, d.email, d.status,
(select dept_name from sys_dept where dept_id = d.parent_id) parent_name
from sys_dept d
where d.dept_id = #{deptId}
</select>
<select id="checkDeptExistUser" parameterType="Long" resultType="int">
select count(1) from sys_user where dept_id = #{deptId} and del_flag = '0'
</select>
<select id="hasChildByDeptId" parameterType="Long" resultType="int">
select count(1) from sys_dept
where del_flag = '0' and parent_id = #{deptId} limit 1
</select>
<select id="selectChildrenDeptById" parameterType="Long" resultMap="SysDeptResult">
select * from sys_dept where find_in_set(#{deptId}, ancestors)
</select>
<select id="selectNormalChildrenDeptById" parameterType="Long" resultType="int">
select count(*) from sys_dept where status = 0 and del_flag = '0' and find_in_set(#{deptId}, ancestors)
</select>
<select id="checkDeptNameUnique" resultMap="SysDeptResult">
<include refid="selectDeptVo"/>
where dept_name=#{deptName} and parent_id = #{parentId} and del_flag = '0' limit 1
</select>
<insert id="insertDept" parameterType="SysDept">
insert into sys_dept(
<if test="deptId != null and deptId != 0">dept_id,</if>
<if test="parentId != null and parentId != 0">parent_id,</if>
<if test="deptName != null and deptName != ''">dept_name,</if>
<if test="ancestors != null and ancestors != ''">ancestors,</if>
<if test="orderNum != null">order_num,</if>
<if test="leader != null and leader != ''">leader,</if>
<if test="phone != null and phone != ''">phone,</if>
<if test="email != null and email != ''">email,</if>
<if test="status != null">status,</if>
<if test="createBy != null and createBy != ''">create_by,</if>
create_time
)values(
<if test="deptId != null and deptId != 0">#{deptId},</if>
<if test="parentId != null and parentId != 0">#{parentId},</if>
<if test="deptName != null and deptName != ''">#{deptName},</if>
<if test="ancestors != null and ancestors != ''">#{ancestors},</if>
<if test="orderNum != null">#{orderNum},</if>
<if test="leader != null and leader != ''">#{leader},</if>
<if test="phone != null and phone != ''">#{phone},</if>
<if test="email != null and email != ''">#{email},</if>
<if test="status != null">#{status},</if>
<if test="createBy != null and createBy != ''">#{createBy},</if>
sysdate()
)
</insert>
<update id="updateDept" parameterType="SysDept">
update sys_dept
<set>
<if test="parentId != null and parentId != 0">parent_id = #{parentId},</if>
<if test="deptName != null and deptName != ''">dept_name = #{deptName},</if>
<if test="ancestors != null and ancestors != ''">ancestors = #{ancestors},</if>
<if test="orderNum != null">order_num = #{orderNum},</if>
<if test="leader != null">leader = #{leader},</if>
<if test="phone != null">phone = #{phone},</if>
<if test="email != null">email = #{email},</if>
<if test="status != null and status != ''">status = #{status},</if>
<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if>
update_time = sysdate()
</set>
where dept_id = #{deptId}
</update>
<update id="updateDeptChildren" parameterType="java.util.List">
update sys_dept set ancestors =
<foreach collection="depts" item="item" index="index"
separator=" " open="case dept_id" close="end">
when #{item.deptId} then #{item.ancestors}
</foreach>
where dept_id in
<foreach collection="depts" item="item" index="index"
separator="," open="(" close=")">
#{item.deptId}
</foreach>
</update>
<update id="updateDeptStatusNormal" parameterType="Long">
update sys_dept set status = '0' where dept_id in
<foreach collection="array" item="deptId" open="(" separator="," close=")">
#{deptId}
</foreach>
</update>
<delete id="deleteDeptById" parameterType="Long">
update sys_dept set del_flag = '2' where dept_id = #{deptId}
</delete>
</mapper>

View File

@ -0,0 +1,124 @@
<?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.system.mapper.SysDictDataMapper">
<resultMap type="SysDictData" id="SysDictDataResult">
<id property="dictCode" column="dict_code" />
<result property="dictSort" column="dict_sort" />
<result property="dictLabel" column="dict_label" />
<result property="dictValue" column="dict_value" />
<result property="dictType" column="dict_type" />
<result property="cssClass" column="css_class" />
<result property="listClass" column="list_class" />
<result property="isDefault" column="is_default" />
<result property="status" column="status" />
<result property="createBy" column="create_by" />
<result property="createTime" column="create_time" />
<result property="updateBy" column="update_by" />
<result property="updateTime" column="update_time" />
</resultMap>
<sql id="selectDictDataVo">
select dict_code, dict_sort, dict_label, dict_value, dict_type, css_class, list_class, is_default, status, create_by, create_time, remark
from sys_dict_data
</sql>
<select id="selectDictDataList" parameterType="SysDictData" resultMap="SysDictDataResult">
<include refid="selectDictDataVo"/>
<where>
<if test="dictType != null and dictType != ''">
AND dict_type = #{dictType}
</if>
<if test="dictLabel != null and dictLabel != ''">
AND dict_label like concat('%', #{dictLabel}, '%')
</if>
<if test="status != null and status != ''">
AND status = #{status}
</if>
</where>
order by dict_sort asc
</select>
<select id="selectDictDataByType" parameterType="String" resultMap="SysDictDataResult">
<include refid="selectDictDataVo"/>
where status = '0' and dict_type = #{dictType} order by dict_sort asc
</select>
<select id="selectDictLabel" resultType="String">
select dict_label from sys_dict_data
where dict_type = #{dictType} and dict_value = #{dictValue}
</select>
<select id="selectDictDataById" parameterType="Long" resultMap="SysDictDataResult">
<include refid="selectDictDataVo"/>
where dict_code = #{dictCode}
</select>
<select id="countDictDataByType" resultType="Integer">
select count(1) from sys_dict_data where dict_type=#{dictType}
</select>
<delete id="deleteDictDataById" parameterType="Long">
delete from sys_dict_data where dict_code = #{dictCode}
</delete>
<delete id="deleteDictDataByIds" parameterType="Long">
delete from sys_dict_data where dict_code in
<foreach collection="array" item="dictCode" open="(" separator="," close=")">
#{dictCode}
</foreach>
</delete>
<update id="updateDictData" parameterType="SysDictData">
update sys_dict_data
<set>
<if test="dictSort != null">dict_sort = #{dictSort},</if>
<if test="dictLabel != null and dictLabel != ''">dict_label = #{dictLabel},</if>
<if test="dictValue != null and dictValue != ''">dict_value = #{dictValue},</if>
<if test="dictType != null and dictType != ''">dict_type = #{dictType},</if>
<if test="cssClass != null">css_class = #{cssClass},</if>
<if test="listClass != null">list_class = #{listClass},</if>
<if test="isDefault != null and isDefault != ''">is_default = #{isDefault},</if>
<if test="status != null">status = #{status},</if>
<if test="remark != null">remark = #{remark},</if>
<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if>
update_time = sysdate()
</set>
where dict_code = #{dictCode}
</update>
<update id="updateDictDataType" parameterType="String">
update sys_dict_data set dict_type = #{newDictType} where dict_type = #{oldDictType}
</update>
<insert id="insertDictData" parameterType="SysDictData">
insert into sys_dict_data(
<if test="dictSort != null">dict_sort,</if>
<if test="dictLabel != null and dictLabel != ''">dict_label,</if>
<if test="dictValue != null and dictValue != ''">dict_value,</if>
<if test="dictType != null and dictType != ''">dict_type,</if>
<if test="cssClass != null and cssClass != ''">css_class,</if>
<if test="listClass != null and listClass != ''">list_class,</if>
<if test="isDefault != null and isDefault != ''">is_default,</if>
<if test="status != null">status,</if>
<if test="remark != null and remark != ''">remark,</if>
<if test="createBy != null and createBy != ''">create_by,</if>
create_time
)values(
<if test="dictSort != null">#{dictSort},</if>
<if test="dictLabel != null and dictLabel != ''">#{dictLabel},</if>
<if test="dictValue != null and dictValue != ''">#{dictValue},</if>
<if test="dictType != null and dictType != ''">#{dictType},</if>
<if test="cssClass != null and cssClass != ''">#{cssClass},</if>
<if test="listClass != null and listClass != ''">#{listClass},</if>
<if test="isDefault != null and isDefault != ''">#{isDefault},</if>
<if test="status != null">#{status},</if>
<if test="remark != null and remark != ''">#{remark},</if>
<if test="createBy != null and createBy != ''">#{createBy},</if>
sysdate()
)
</insert>
</mapper>

View File

@ -0,0 +1,105 @@
<?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.system.mapper.SysDictTypeMapper">
<resultMap type="SysDictType" id="SysDictTypeResult">
<id property="dictId" column="dict_id" />
<result property="dictName" column="dict_name" />
<result property="dictType" column="dict_type" />
<result property="status" column="status" />
<result property="createBy" column="create_by" />
<result property="createTime" column="create_time" />
<result property="updateBy" column="update_by" />
<result property="updateTime" column="update_time" />
</resultMap>
<sql id="selectDictTypeVo">
select dict_id, dict_name, dict_type, status, create_by, create_time, remark
from sys_dict_type
</sql>
<select id="selectDictTypeList" parameterType="SysDictType" resultMap="SysDictTypeResult">
<include refid="selectDictTypeVo"/>
<where>
<if test="dictName != null and dictName != ''">
AND dict_name like concat('%', #{dictName}, '%')
</if>
<if test="status != null and status != ''">
AND status = #{status}
</if>
<if test="dictType != null and dictType != ''">
AND dict_type like concat('%', #{dictType}, '%')
</if>
<if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 -->
and date_format(create_time,'%y%m%d') &gt;= date_format(#{params.beginTime},'%y%m%d')
</if>
<if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 -->
and date_format(create_time,'%y%m%d') &lt;= date_format(#{params.endTime},'%y%m%d')
</if>
</where>
</select>
<select id="selectDictTypeAll" resultMap="SysDictTypeResult">
<include refid="selectDictTypeVo"/>
</select>
<select id="selectDictTypeById" parameterType="Long" resultMap="SysDictTypeResult">
<include refid="selectDictTypeVo"/>
where dict_id = #{dictId}
</select>
<select id="selectDictTypeByType" parameterType="String" resultMap="SysDictTypeResult">
<include refid="selectDictTypeVo"/>
where dict_type = #{dictType}
</select>
<select id="checkDictTypeUnique" parameterType="String" resultMap="SysDictTypeResult">
<include refid="selectDictTypeVo"/>
where dict_type = #{dictType} limit 1
</select>
<delete id="deleteDictTypeById" parameterType="Long">
delete from sys_dict_type where dict_id = #{dictId}
</delete>
<delete id="deleteDictTypeByIds" parameterType="Long">
delete from sys_dict_type where dict_id in
<foreach collection="array" item="dictId" open="(" separator="," close=")">
#{dictId}
</foreach>
</delete>
<update id="updateDictType" parameterType="SysDictType">
update sys_dict_type
<set>
<if test="dictName != null and dictName != ''">dict_name = #{dictName},</if>
<if test="dictType != null and dictType != ''">dict_type = #{dictType},</if>
<if test="status != null">status = #{status},</if>
<if test="remark != null">remark = #{remark},</if>
<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if>
update_time = sysdate()
</set>
where dict_id = #{dictId}
</update>
<insert id="insertDictType" parameterType="SysDictType">
insert into sys_dict_type(
<if test="dictName != null and dictName != ''">dict_name,</if>
<if test="dictType != null and dictType != ''">dict_type,</if>
<if test="status != null">status,</if>
<if test="remark != null and remark != ''">remark,</if>
<if test="createBy != null and createBy != ''">create_by,</if>
create_time
)values(
<if test="dictName != null and dictName != ''">#{dictName},</if>
<if test="dictType != null and dictType != ''">#{dictType},</if>
<if test="status != null">#{status},</if>
<if test="remark != null and remark != ''">#{remark},</if>
<if test="createBy != null and createBy != ''">#{createBy},</if>
sysdate()
)
</insert>
</mapper>

View File

@ -0,0 +1,57 @@
<?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.system.mapper.SysLogininforMapper">
<resultMap type="SysLogininfor" id="SysLogininforResult">
<id property="infoId" column="info_id" />
<result property="userName" column="user_name" />
<result property="status" column="status" />
<result property="ipaddr" column="ipaddr" />
<result property="loginLocation" column="login_location" />
<result property="browser" column="browser" />
<result property="os" column="os" />
<result property="msg" column="msg" />
<result property="loginTime" column="login_time" />
</resultMap>
<insert id="insertLogininfor" parameterType="SysLogininfor">
insert into sys_logininfor (user_name, status, ipaddr, login_location, browser, os, msg, login_time)
values (#{userName}, #{status}, #{ipaddr}, #{loginLocation}, #{browser}, #{os}, #{msg}, sysdate())
</insert>
<select id="selectLogininforList" parameterType="SysLogininfor" resultMap="SysLogininforResult">
select info_id, user_name, ipaddr, login_location, browser, os, status, msg, login_time from sys_logininfor
<where>
<if test="ipaddr != null and ipaddr != ''">
AND ipaddr like concat('%', #{ipaddr}, '%')
</if>
<if test="status != null and status != ''">
AND status = #{status}
</if>
<if test="userName != null and userName != ''">
AND user_name like concat('%', #{userName}, '%')
</if>
<if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 -->
AND login_time &gt;= #{params.beginTime}
</if>
<if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 -->
AND login_time &lt;= #{params.endTime}
</if>
</where>
order by info_id desc
</select>
<delete id="deleteLogininforByIds" parameterType="Long">
delete from sys_logininfor where info_id in
<foreach collection="array" item="infoId" open="(" separator="," close=")">
#{infoId}
</foreach>
</delete>
<update id="cleanLogininfor">
truncate table sys_logininfor
</update>
</mapper>

View File

@ -0,0 +1,206 @@
<?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.system.mapper.SysMenuMapper">
<resultMap type="SysMenu" id="SysMenuResult">
<id property="menuId" column="menu_id" />
<result property="menuName" column="menu_name" />
<result property="parentName" column="parent_name" />
<result property="parentId" column="parent_id" />
<result property="orderNum" column="order_num" />
<result property="path" column="path" />
<result property="component" column="component" />
<result property="query" column="query" />
<result property="routeName" column="route_name" />
<result property="isFrame" column="is_frame" />
<result property="isCache" column="is_cache" />
<result property="menuType" column="menu_type" />
<result property="visible" column="visible" />
<result property="status" column="status" />
<result property="perms" column="perms" />
<result property="icon" column="icon" />
<result property="createBy" column="create_by" />
<result property="createTime" column="create_time" />
<result property="updateTime" column="update_time" />
<result property="updateBy" column="update_by" />
<result property="remark" column="remark" />
</resultMap>
<sql id="selectMenuVo">
select menu_id, menu_name, parent_id, order_num, path, component, `query`, route_name, is_frame, is_cache, menu_type, visible, status, ifnull(perms,'') as perms, icon, create_time
from sys_menu
</sql>
<select id="selectMenuList" parameterType="SysMenu" resultMap="SysMenuResult">
<include refid="selectMenuVo"/>
<where>
<if test="menuName != null and menuName != ''">
AND menu_name like concat('%', #{menuName}, '%')
</if>
<if test="visible != null and visible != ''">
AND visible = #{visible}
</if>
<if test="status != null and status != ''">
AND status = #{status}
</if>
</where>
order by parent_id, order_num
</select>
<select id="selectMenuTreeAll" resultMap="SysMenuResult">
select distinct m.menu_id, m.parent_id, m.menu_name, m.path, m.component, m.`query`, m.route_name, m.visible, m.status, ifnull(m.perms,'') as perms, m.is_frame, m.is_cache, m.menu_type, m.icon, m.order_num, m.create_time
from sys_menu m where m.menu_type in ('M', 'C') and m.status = 0
order by m.parent_id, m.order_num
</select>
<select id="selectMenuListByUserId" parameterType="SysMenu" resultMap="SysMenuResult">
select distinct m.menu_id, m.parent_id, m.menu_name, m.path, m.component, m.`query`, m.route_name, m.visible, m.status, ifnull(m.perms,'') as perms, m.is_frame, m.is_cache, m.menu_type, m.icon, m.order_num, m.create_time
from sys_menu m
left join sys_role_menu rm on m.menu_id = rm.menu_id
left join sys_user_role ur on rm.role_id = ur.role_id
left join sys_role ro on ur.role_id = ro.role_id
where ur.user_id = #{params.userId}
<if test="menuName != null and menuName != ''">
AND m.menu_name like concat('%', #{menuName}, '%')
</if>
<if test="visible != null and visible != ''">
AND m.visible = #{visible}
</if>
<if test="status != null and status != ''">
AND m.status = #{status}
</if>
order by m.parent_id, m.order_num
</select>
<select id="selectMenuTreeByUserId" parameterType="Long" resultMap="SysMenuResult">
select distinct m.menu_id, m.parent_id, m.menu_name, m.path, m.component, m.`query`, m.route_name, m.visible, m.status, ifnull(m.perms,'') as perms, m.is_frame, m.is_cache, m.menu_type, m.icon, m.order_num, m.create_time
from sys_menu m
left join sys_role_menu rm on m.menu_id = rm.menu_id
left join sys_user_role ur on rm.role_id = ur.role_id
left join sys_role ro on ur.role_id = ro.role_id
left join sys_user u on ur.user_id = u.user_id
where u.user_id = #{userId} and m.menu_type in ('M', 'C') and m.status = 0 AND ro.status = 0
order by m.parent_id, m.order_num
</select>
<select id="selectMenuListByRoleId" resultType="Long">
select m.menu_id
from sys_menu m
left join sys_role_menu rm on m.menu_id = rm.menu_id
where rm.role_id = #{roleId}
<if test="menuCheckStrictly">
and m.menu_id not in (select m.parent_id from sys_menu m inner join sys_role_menu rm on m.menu_id = rm.menu_id and rm.role_id = #{roleId})
</if>
order by m.parent_id, m.order_num
</select>
<select id="selectMenuPerms" resultType="String">
select distinct m.perms
from sys_menu m
left join sys_role_menu rm on m.menu_id = rm.menu_id
left join sys_user_role ur on rm.role_id = ur.role_id
</select>
<select id="selectMenuPermsByUserId" parameterType="Long" resultType="String">
select distinct m.perms
from sys_menu m
left join sys_role_menu rm on m.menu_id = rm.menu_id
left join sys_user_role ur on rm.role_id = ur.role_id
left join sys_role r on r.role_id = ur.role_id
where m.status = '0' and r.status = '0' and ur.user_id = #{userId}
</select>
<select id="selectMenuPermsByRoleId" parameterType="Long" resultType="String">
select distinct m.perms
from sys_menu m
left join sys_role_menu rm on m.menu_id = rm.menu_id
where m.status = '0' and rm.role_id = #{roleId}
</select>
<select id="selectMenuById" parameterType="Long" resultMap="SysMenuResult">
<include refid="selectMenuVo"/>
where menu_id = #{menuId}
</select>
<select id="hasChildByMenuId" resultType="Integer">
select count(1) from sys_menu where parent_id = #{menuId}
</select>
<select id="checkMenuNameUnique" parameterType="SysMenu" resultMap="SysMenuResult">
<include refid="selectMenuVo"/>
where menu_name=#{menuName} and parent_id = #{parentId} limit 1
</select>
<update id="updateMenu" parameterType="SysMenu">
update sys_menu
<set>
<if test="menuName != null and menuName != ''">menu_name = #{menuName},</if>
<if test="parentId != null">parent_id = #{parentId},</if>
<if test="orderNum != null">order_num = #{orderNum},</if>
<if test="path != null and path != ''">path = #{path},</if>
<if test="component != null">component = #{component},</if>
<if test="query != null">`query` = #{query},</if>
<if test="routeName != null">route_name = #{routeName},</if>
<if test="isFrame != null and isFrame != ''">is_frame = #{isFrame},</if>
<if test="isCache != null and isCache != ''">is_cache = #{isCache},</if>
<if test="menuType != null and menuType != ''">menu_type = #{menuType},</if>
<if test="visible != null">visible = #{visible},</if>
<if test="status != null">status = #{status},</if>
<if test="perms !=null">perms = #{perms},</if>
<if test="icon !=null and icon != ''">icon = #{icon},</if>
<if test="remark != null and remark != ''">remark = #{remark},</if>
<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if>
update_time = sysdate()
</set>
where menu_id = #{menuId}
</update>
<insert id="insertMenu" parameterType="SysMenu">
insert into sys_menu(
<if test="menuId != null and menuId != 0">menu_id,</if>
<if test="parentId != null and parentId != 0">parent_id,</if>
<if test="menuName != null and menuName != ''">menu_name,</if>
<if test="orderNum != null">order_num,</if>
<if test="path != null and path != ''">path,</if>
<if test="component != null and component != ''">component,</if>
<if test="query != null and query != ''">`query`,</if>
<if test="routeName != null">route_name,</if>
<if test="isFrame != null and isFrame != ''">is_frame,</if>
<if test="isCache != null and isCache != ''">is_cache,</if>
<if test="menuType != null and menuType != ''">menu_type,</if>
<if test="visible != null">visible,</if>
<if test="status != null">status,</if>
<if test="perms !=null and perms != ''">perms,</if>
<if test="icon != null and icon != ''">icon,</if>
<if test="remark != null and remark != ''">remark,</if>
<if test="createBy != null and createBy != ''">create_by,</if>
create_time
)values(
<if test="menuId != null and menuId != 0">#{menuId},</if>
<if test="parentId != null and parentId != 0">#{parentId},</if>
<if test="menuName != null and menuName != ''">#{menuName},</if>
<if test="orderNum != null">#{orderNum},</if>
<if test="path != null and path != ''">#{path},</if>
<if test="component != null and component != ''">#{component},</if>
<if test="query != null and query != ''">#{query},</if>
<if test="routeName != null">#{routeName},</if>
<if test="isFrame != null and isFrame != ''">#{isFrame},</if>
<if test="isCache != null and isCache != ''">#{isCache},</if>
<if test="menuType != null and menuType != ''">#{menuType},</if>
<if test="visible != null">#{visible},</if>
<if test="status != null">#{status},</if>
<if test="perms !=null and perms != ''">#{perms},</if>
<if test="icon != null and icon != ''">#{icon},</if>
<if test="remark != null and remark != ''">#{remark},</if>
<if test="createBy != null and createBy != ''">#{createBy},</if>
sysdate()
)
</insert>
<delete id="deleteMenuById" parameterType="Long">
delete from sys_menu where menu_id = #{menuId}
</delete>
</mapper>

View File

@ -0,0 +1,89 @@
<?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.system.mapper.SysNoticeMapper">
<resultMap type="SysNotice" id="SysNoticeResult">
<result property="noticeId" column="notice_id" />
<result property="noticeTitle" column="notice_title" />
<result property="noticeType" column="notice_type" />
<result property="noticeContent" column="notice_content" />
<result property="status" column="status" />
<result property="createBy" column="create_by" />
<result property="createTime" column="create_time" />
<result property="updateBy" column="update_by" />
<result property="updateTime" column="update_time" />
<result property="remark" column="remark" />
</resultMap>
<sql id="selectNoticeVo">
select notice_id, notice_title, notice_type, cast(notice_content as char) as notice_content, status, create_by, create_time, update_by, update_time, remark
from sys_notice
</sql>
<select id="selectNoticeById" parameterType="Long" resultMap="SysNoticeResult">
<include refid="selectNoticeVo"/>
where notice_id = #{noticeId}
</select>
<select id="selectNoticeList" parameterType="SysNotice" resultMap="SysNoticeResult">
<include refid="selectNoticeVo"/>
<where>
<if test="noticeTitle != null and noticeTitle != ''">
AND notice_title like concat('%', #{noticeTitle}, '%')
</if>
<if test="noticeType != null and noticeType != ''">
AND notice_type = #{noticeType}
</if>
<if test="createBy != null and createBy != ''">
AND create_by like concat('%', #{createBy}, '%')
</if>
</where>
</select>
<insert id="insertNotice" parameterType="SysNotice">
insert into sys_notice (
<if test="noticeTitle != null and noticeTitle != '' ">notice_title, </if>
<if test="noticeType != null and noticeType != '' ">notice_type, </if>
<if test="noticeContent != null and noticeContent != '' ">notice_content, </if>
<if test="status != null and status != '' ">status, </if>
<if test="remark != null and remark != ''">remark,</if>
<if test="createBy != null and createBy != ''">create_by,</if>
create_time
)values(
<if test="noticeTitle != null and noticeTitle != ''">#{noticeTitle}, </if>
<if test="noticeType != null and noticeType != ''">#{noticeType}, </if>
<if test="noticeContent != null and noticeContent != ''">#{noticeContent}, </if>
<if test="status != null and status != ''">#{status}, </if>
<if test="remark != null and remark != ''">#{remark},</if>
<if test="createBy != null and createBy != ''">#{createBy},</if>
sysdate()
)
</insert>
<update id="updateNotice" parameterType="SysNotice">
update sys_notice
<set>
<if test="noticeTitle != null and noticeTitle != ''">notice_title = #{noticeTitle}, </if>
<if test="noticeType != null and noticeType != ''">notice_type = #{noticeType}, </if>
<if test="noticeContent != null">notice_content = #{noticeContent}, </if>
<if test="status != null and status != ''">status = #{status}, </if>
<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if>
update_time = sysdate()
</set>
where notice_id = #{noticeId}
</update>
<delete id="deleteNoticeById" parameterType="Long">
delete from sys_notice where notice_id = #{noticeId}
</delete>
<delete id="deleteNoticeByIds" parameterType="Long">
delete from sys_notice where notice_id in
<foreach item="noticeId" collection="array" open="(" separator="," close=")">
#{noticeId}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,87 @@
<?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.system.mapper.SysOperLogMapper">
<resultMap type="SysOperLog" id="SysOperLogResult">
<id property="operId" column="oper_id" />
<result property="title" column="title" />
<result property="businessType" column="business_type" />
<result property="method" column="method" />
<result property="requestMethod" column="request_method" />
<result property="operatorType" column="operator_type" />
<result property="operName" column="oper_name" />
<result property="deptName" column="dept_name" />
<result property="operUrl" column="oper_url" />
<result property="operIp" column="oper_ip" />
<result property="operLocation" column="oper_location" />
<result property="operParam" column="oper_param" />
<result property="jsonResult" column="json_result" />
<result property="status" column="status" />
<result property="errorMsg" column="error_msg" />
<result property="operTime" column="oper_time" />
<result property="costTime" column="cost_time" />
</resultMap>
<sql id="selectOperLogVo">
select oper_id, title, business_type, method, request_method, operator_type, oper_name, dept_name, oper_url, oper_ip, oper_location, oper_param, json_result, status, error_msg, oper_time, cost_time
from sys_oper_log
</sql>
<insert id="insertOperlog" parameterType="SysOperLog">
insert into sys_oper_log(title, business_type, method, request_method, operator_type, oper_name, dept_name, oper_url, oper_ip, oper_location, oper_param, json_result, status, error_msg, cost_time, oper_time)
values (#{title}, #{businessType}, #{method}, #{requestMethod}, #{operatorType}, #{operName}, #{deptName}, #{operUrl}, #{operIp}, #{operLocation}, #{operParam}, #{jsonResult}, #{status}, #{errorMsg}, #{costTime}, sysdate())
</insert>
<select id="selectOperLogList" parameterType="SysOperLog" resultMap="SysOperLogResult">
<include refid="selectOperLogVo"/>
<where>
<if test="operIp != null and operIp != ''">
AND oper_ip like concat('%', #{operIp}, '%')
</if>
<if test="title != null and title != ''">
AND title like concat('%', #{title}, '%')
</if>
<if test="businessType != null">
AND business_type = #{businessType}
</if>
<if test="businessTypes != null and businessTypes.length > 0">
AND business_type in
<foreach collection="businessTypes" item="businessType" open="(" separator="," close=")">
#{businessType}
</foreach>
</if>
<if test="status != null">
AND status = #{status}
</if>
<if test="operName != null and operName != ''">
AND oper_name like concat('%', #{operName}, '%')
</if>
<if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 -->
AND oper_time &gt;= #{params.beginTime}
</if>
<if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 -->
AND oper_time &lt;= #{params.endTime}
</if>
</where>
order by oper_id desc
</select>
<delete id="deleteOperLogByIds" parameterType="Long">
delete from sys_oper_log where oper_id in
<foreach collection="array" item="operId" open="(" separator="," close=")">
#{operId}
</foreach>
</delete>
<select id="selectOperLogById" parameterType="Long" resultMap="SysOperLogResult">
<include refid="selectOperLogVo"/>
where oper_id = #{operId}
</select>
<update id="cleanOperLog">
truncate table sys_oper_log
</update>
</mapper>

View File

@ -0,0 +1,122 @@
<?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.system.mapper.SysPostMapper">
<resultMap type="SysPost" id="SysPostResult">
<id property="postId" column="post_id" />
<result property="postCode" column="post_code" />
<result property="postName" column="post_name" />
<result property="postSort" column="post_sort" />
<result property="status" column="status" />
<result property="createBy" column="create_by" />
<result property="createTime" column="create_time" />
<result property="updateBy" column="update_by" />
<result property="updateTime" column="update_time" />
<result property="remark" column="remark" />
</resultMap>
<sql id="selectPostVo">
select post_id, post_code, post_name, post_sort, status, create_by, create_time, remark
from sys_post
</sql>
<select id="selectPostList" parameterType="SysPost" resultMap="SysPostResult">
<include refid="selectPostVo"/>
<where>
<if test="postCode != null and postCode != ''">
AND post_code like concat('%', #{postCode}, '%')
</if>
<if test="status != null and status != ''">
AND status = #{status}
</if>
<if test="postName != null and postName != ''">
AND post_name like concat('%', #{postName}, '%')
</if>
</where>
</select>
<select id="selectPostAll" resultMap="SysPostResult">
<include refid="selectPostVo"/>
</select>
<select id="selectPostById" parameterType="Long" resultMap="SysPostResult">
<include refid="selectPostVo"/>
where post_id = #{postId}
</select>
<select id="selectPostListByUserId" parameterType="Long" resultType="Long">
select p.post_id
from sys_post p
left join sys_user_post up on up.post_id = p.post_id
left join sys_user u on u.user_id = up.user_id
where u.user_id = #{userId}
</select>
<select id="selectPostsByUserName" parameterType="String" resultMap="SysPostResult">
select p.post_id, p.post_name, p.post_code
from sys_post p
left join sys_user_post up on up.post_id = p.post_id
left join sys_user u on u.user_id = up.user_id
where u.user_name = #{userName}
</select>
<select id="checkPostNameUnique" parameterType="String" resultMap="SysPostResult">
<include refid="selectPostVo"/>
where post_name=#{postName} limit 1
</select>
<select id="checkPostCodeUnique" parameterType="String" resultMap="SysPostResult">
<include refid="selectPostVo"/>
where post_code=#{postCode} limit 1
</select>
<update id="updatePost" parameterType="SysPost">
update sys_post
<set>
<if test="postCode != null and postCode != ''">post_code = #{postCode},</if>
<if test="postName != null and postName != ''">post_name = #{postName},</if>
<if test="postSort != null">post_sort = #{postSort},</if>
<if test="status != null and status != ''">status = #{status},</if>
<if test="remark != null">remark = #{remark},</if>
<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if>
update_time = sysdate()
</set>
where post_id = #{postId}
</update>
<insert id="insertPost" parameterType="SysPost" useGeneratedKeys="true" keyProperty="postId">
insert into sys_post(
<if test="postId != null and postId != 0">post_id,</if>
<if test="postCode != null and postCode != ''">post_code,</if>
<if test="postName != null and postName != ''">post_name,</if>
<if test="postSort != null">post_sort,</if>
<if test="status != null and status != ''">status,</if>
<if test="remark != null and remark != ''">remark,</if>
<if test="createBy != null and createBy != ''">create_by,</if>
create_time
)values(
<if test="postId != null and postId != 0">#{postId},</if>
<if test="postCode != null and postCode != ''">#{postCode},</if>
<if test="postName != null and postName != ''">#{postName},</if>
<if test="postSort != null">#{postSort},</if>
<if test="status != null and status != ''">#{status},</if>
<if test="remark != null and remark != ''">#{remark},</if>
<if test="createBy != null and createBy != ''">#{createBy},</if>
sysdate()
)
</insert>
<delete id="deletePostById" parameterType="Long">
delete from sys_post where post_id = #{postId}
</delete>
<delete id="deletePostByIds" parameterType="Long">
delete from sys_post where post_id in
<foreach collection="array" item="postId" open="(" separator="," close=")">
#{postId}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,34 @@
<?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.system.mapper.SysRoleDeptMapper">
<resultMap type="SysRoleDept" id="SysRoleDeptResult">
<result property="roleId" column="role_id" />
<result property="deptId" column="dept_id" />
</resultMap>
<delete id="deleteRoleDeptByRoleId" parameterType="Long">
delete from sys_role_dept where role_id=#{roleId}
</delete>
<select id="selectCountRoleDeptByDeptId" resultType="Integer">
select count(1) from sys_role_dept where dept_id=#{deptId}
</select>
<delete id="deleteRoleDept" parameterType="Long">
delete from sys_role_dept where role_id in
<foreach collection="array" item="roleId" open="(" separator="," close=")">
#{roleId}
</foreach>
</delete>
<insert id="batchRoleDept">
insert into sys_role_dept(role_id, dept_id) values
<foreach item="item" index="index" collection="list" separator=",">
(#{item.roleId},#{item.deptId})
</foreach>
</insert>
</mapper>

View File

@ -0,0 +1,152 @@
<?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.system.mapper.SysRoleMapper">
<resultMap type="SysRole" id="SysRoleResult">
<id property="roleId" column="role_id" />
<result property="roleName" column="role_name" />
<result property="roleKey" column="role_key" />
<result property="roleSort" column="role_sort" />
<result property="dataScope" column="data_scope" />
<result property="menuCheckStrictly" column="menu_check_strictly" />
<result property="deptCheckStrictly" column="dept_check_strictly" />
<result property="status" column="status" />
<result property="delFlag" column="del_flag" />
<result property="createBy" column="create_by" />
<result property="createTime" column="create_time" />
<result property="updateBy" column="update_by" />
<result property="updateTime" column="update_time" />
<result property="remark" column="remark" />
</resultMap>
<sql id="selectRoleVo">
select distinct r.role_id, r.role_name, r.role_key, r.role_sort, r.data_scope, r.menu_check_strictly, r.dept_check_strictly,
r.status, r.del_flag, r.create_time, r.remark
from sys_role r
left join sys_user_role ur on ur.role_id = r.role_id
left join sys_user u on u.user_id = ur.user_id
left join sys_dept d on u.dept_id = d.dept_id
</sql>
<select id="selectRoleList" parameterType="SysRole" resultMap="SysRoleResult">
<include refid="selectRoleVo"/>
where r.del_flag = '0'
<if test="roleId != null and roleId != 0">
AND r.role_id = #{roleId}
</if>
<if test="roleName != null and roleName != ''">
AND r.role_name like concat('%', #{roleName}, '%')
</if>
<if test="status != null and status != ''">
AND r.status = #{status}
</if>
<if test="roleKey != null and roleKey != ''">
AND r.role_key like concat('%', #{roleKey}, '%')
</if>
<if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 -->
and date_format(r.create_time,'%y%m%d') &gt;= date_format(#{params.beginTime},'%y%m%d')
</if>
<if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 -->
and date_format(r.create_time,'%y%m%d') &lt;= date_format(#{params.endTime},'%y%m%d')
</if>
<!-- 数据范围过滤 -->
${params.dataScope}
order by r.role_sort
</select>
<select id="selectRolePermissionByUserId" parameterType="Long" resultMap="SysRoleResult">
<include refid="selectRoleVo"/>
WHERE r.del_flag = '0' and ur.user_id = #{userId}
</select>
<select id="selectRoleAll" resultMap="SysRoleResult">
<include refid="selectRoleVo"/>
</select>
<select id="selectRoleListByUserId" parameterType="Long" resultType="Long">
select r.role_id
from sys_role r
left join sys_user_role ur on ur.role_id = r.role_id
left join sys_user u on u.user_id = ur.user_id
where u.user_id = #{userId}
</select>
<select id="selectRoleById" parameterType="Long" resultMap="SysRoleResult">
<include refid="selectRoleVo"/>
where r.role_id = #{roleId}
</select>
<select id="selectRolesByUserName" parameterType="String" resultMap="SysRoleResult">
<include refid="selectRoleVo"/>
WHERE r.del_flag = '0' and u.user_name = #{userName}
</select>
<select id="checkRoleNameUnique" parameterType="String" resultMap="SysRoleResult">
<include refid="selectRoleVo"/>
where r.role_name=#{roleName} and r.del_flag = '0' limit 1
</select>
<select id="checkRoleKeyUnique" parameterType="String" resultMap="SysRoleResult">
<include refid="selectRoleVo"/>
where r.role_key=#{roleKey} and r.del_flag = '0' limit 1
</select>
<insert id="insertRole" parameterType="SysRole" useGeneratedKeys="true" keyProperty="roleId">
insert into sys_role(
<if test="roleId != null and roleId != 0">role_id,</if>
<if test="roleName != null and roleName != ''">role_name,</if>
<if test="roleKey != null and roleKey != ''">role_key,</if>
<if test="roleSort != null">role_sort,</if>
<if test="dataScope != null and dataScope != ''">data_scope,</if>
<if test="menuCheckStrictly != null">menu_check_strictly,</if>
<if test="deptCheckStrictly != null">dept_check_strictly,</if>
<if test="status != null and status != ''">status,</if>
<if test="remark != null and remark != ''">remark,</if>
<if test="createBy != null and createBy != ''">create_by,</if>
create_time
)values(
<if test="roleId != null and roleId != 0">#{roleId},</if>
<if test="roleName != null and roleName != ''">#{roleName},</if>
<if test="roleKey != null and roleKey != ''">#{roleKey},</if>
<if test="roleSort != null">#{roleSort},</if>
<if test="dataScope != null and dataScope != ''">#{dataScope},</if>
<if test="menuCheckStrictly != null">#{menuCheckStrictly},</if>
<if test="deptCheckStrictly != null">#{deptCheckStrictly},</if>
<if test="status != null and status != ''">#{status},</if>
<if test="remark != null and remark != ''">#{remark},</if>
<if test="createBy != null and createBy != ''">#{createBy},</if>
sysdate()
)
</insert>
<update id="updateRole" parameterType="SysRole">
update sys_role
<set>
<if test="roleName != null and roleName != ''">role_name = #{roleName},</if>
<if test="roleKey != null and roleKey != ''">role_key = #{roleKey},</if>
<if test="roleSort != null">role_sort = #{roleSort},</if>
<if test="dataScope != null and dataScope != ''">data_scope = #{dataScope},</if>
<if test="menuCheckStrictly != null">menu_check_strictly = #{menuCheckStrictly},</if>
<if test="deptCheckStrictly != null">dept_check_strictly = #{deptCheckStrictly},</if>
<if test="status != null and status != ''">status = #{status},</if>
<if test="remark != null">remark = #{remark},</if>
<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if>
update_time = sysdate()
</set>
where role_id = #{roleId}
</update>
<delete id="deleteRoleById" parameterType="Long">
update sys_role set del_flag = '2' where role_id = #{roleId}
</delete>
<delete id="deleteRoleByIds" parameterType="Long">
update sys_role set del_flag = '2' where role_id in
<foreach collection="array" item="roleId" open="(" separator="," close=")">
#{roleId}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,34 @@
<?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.system.mapper.SysRoleMenuMapper">
<resultMap type="SysRoleMenu" id="SysRoleMenuResult">
<result property="roleId" column="role_id" />
<result property="menuId" column="menu_id" />
</resultMap>
<select id="checkMenuExistRole" resultType="Integer">
select count(1) from sys_role_menu where menu_id = #{menuId}
</select>
<delete id="deleteRoleMenuByRoleId" parameterType="Long">
delete from sys_role_menu where role_id=#{roleId}
</delete>
<delete id="deleteRoleMenu" parameterType="Long">
delete from sys_role_menu where role_id in
<foreach collection="array" item="roleId" open="(" separator="," close=")">
#{roleId}
</foreach>
</delete>
<insert id="batchRoleMenu">
insert into sys_role_menu(role_id, menu_id) values
<foreach item="item" index="index" collection="list" separator=",">
(#{item.roleId},#{item.menuId})
</foreach>
</insert>
</mapper>

View File

@ -0,0 +1,221 @@
<?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.system.mapper.SysUserMapper">
<resultMap type="SysUser" id="SysUserResult">
<id property="userId" column="user_id" />
<result property="deptId" column="dept_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="password" column="password" />
<result property="status" column="status" />
<result property="delFlag" column="del_flag" />
<result property="loginIp" column="login_ip" />
<result property="loginDate" column="login_date" />
<result property="createBy" column="create_by" />
<result property="createTime" column="create_time" />
<result property="updateBy" column="update_by" />
<result property="updateTime" column="update_time" />
<result property="remark" column="remark" />
<association property="dept" javaType="SysDept" resultMap="deptResult" />
<collection property="roles" javaType="java.util.List" resultMap="RoleResult" />
</resultMap>
<resultMap id="deptResult" type="SysDept">
<id property="deptId" column="dept_id" />
<result property="parentId" column="parent_id" />
<result property="deptName" column="dept_name" />
<result property="ancestors" column="ancestors" />
<result property="orderNum" column="order_num" />
<result property="leader" column="leader" />
<result property="status" column="dept_status" />
</resultMap>
<resultMap id="RoleResult" type="SysRole">
<id property="roleId" column="role_id" />
<result property="roleName" column="role_name" />
<result property="roleKey" column="role_key" />
<result property="roleSort" column="role_sort" />
<result property="dataScope" column="data_scope" />
<result property="status" column="role_status" />
</resultMap>
<sql id="selectUserVo">
select u.user_id, u.dept_id, u.user_name, u.nick_name, u.email, u.avatar, u.phonenumber, u.password, u.sex, u.status, u.del_flag, u.login_ip, u.login_date, u.create_by, u.create_time, u.remark,
d.dept_id, d.parent_id, d.ancestors, d.dept_name, d.order_num, d.leader, d.status as dept_status,
r.role_id, r.role_name, r.role_key, r.role_sort, r.data_scope, r.status as role_status
from sys_user u
left join sys_dept d on u.dept_id = d.dept_id
left join sys_user_role ur on u.user_id = ur.user_id
left join sys_role r on r.role_id = ur.role_id
</sql>
<select id="selectUserList" parameterType="SysUser" resultMap="SysUserResult">
select u.user_id, u.dept_id, u.nick_name, u.user_name, u.email, u.avatar, u.phonenumber, u.sex, u.status, u.del_flag, u.login_ip, u.login_date, u.create_by, u.create_time, u.remark, d.dept_name, d.leader from sys_user u
left join sys_dept d on u.dept_id = d.dept_id
where u.del_flag = '0'
<if test="userId != null and userId != 0">
AND u.user_id = #{userId}
</if>
<if test="userName != null and userName != ''">
AND u.user_name like concat('%', #{userName}, '%')
</if>
<if test="status != null and status != ''">
AND u.status = #{status}
</if>
<if test="phonenumber != null and phonenumber != ''">
AND u.phonenumber like concat('%', #{phonenumber}, '%')
</if>
<if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 -->
AND date_format(u.create_time,'%y%m%d') &gt;= date_format(#{params.beginTime},'%y%m%d')
</if>
<if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 -->
AND date_format(u.create_time,'%y%m%d') &lt;= date_format(#{params.endTime},'%y%m%d')
</if>
<if test="deptId != null and deptId != 0">
AND (u.dept_id = #{deptId} OR u.dept_id IN ( SELECT t.dept_id FROM sys_dept t WHERE find_in_set(#{deptId}, ancestors) ))
</if>
<!-- 数据范围过滤 -->
${params.dataScope}
</select>
<select id="selectAllocatedList" parameterType="SysUser" resultMap="SysUserResult">
select distinct u.user_id, u.dept_id, u.user_name, u.nick_name, u.email, u.phonenumber, u.status, u.create_time
from sys_user u
left join sys_dept d on u.dept_id = d.dept_id
left join sys_user_role ur on u.user_id = ur.user_id
left join sys_role r on r.role_id = ur.role_id
where u.del_flag = '0' and r.role_id = #{roleId}
<if test="userName != null and userName != ''">
AND u.user_name like concat('%', #{userName}, '%')
</if>
<if test="phonenumber != null and phonenumber != ''">
AND u.phonenumber like concat('%', #{phonenumber}, '%')
</if>
<!-- 数据范围过滤 -->
${params.dataScope}
</select>
<select id="selectUnallocatedList" parameterType="SysUser" resultMap="SysUserResult">
select distinct u.user_id, u.dept_id, u.user_name, u.nick_name, u.email, u.phonenumber, u.status, u.create_time
from sys_user u
left join sys_dept d on u.dept_id = d.dept_id
left join sys_user_role ur on u.user_id = ur.user_id
left join sys_role r on r.role_id = ur.role_id
where u.del_flag = '0' and (r.role_id != #{roleId} or r.role_id IS NULL)
and u.user_id not in (select u.user_id from sys_user u inner join sys_user_role ur on u.user_id = ur.user_id and ur.role_id = #{roleId})
<if test="userName != null and userName != ''">
AND u.user_name like concat('%', #{userName}, '%')
</if>
<if test="phonenumber != null and phonenumber != ''">
AND u.phonenumber like concat('%', #{phonenumber}, '%')
</if>
<!-- 数据范围过滤 -->
${params.dataScope}
</select>
<select id="selectUserByUserName" parameterType="String" resultMap="SysUserResult">
<include refid="selectUserVo"/>
where u.user_name = #{userName} and u.del_flag = '0'
</select>
<select id="selectUserById" parameterType="Long" resultMap="SysUserResult">
<include refid="selectUserVo"/>
where u.user_id = #{userId}
</select>
<select id="checkUserNameUnique" parameterType="String" resultMap="SysUserResult">
select user_id, user_name from sys_user where user_name = #{userName} and del_flag = '0' limit 1
</select>
<select id="checkPhoneUnique" parameterType="String" resultMap="SysUserResult">
select user_id, phonenumber from sys_user where phonenumber = #{phonenumber} and del_flag = '0' limit 1
</select>
<select id="checkEmailUnique" parameterType="String" resultMap="SysUserResult">
select user_id, email from sys_user where email = #{email} and del_flag = '0' limit 1
</select>
<insert id="insertUser" parameterType="SysUser" useGeneratedKeys="true" keyProperty="userId">
insert into sys_user(
<if test="userId != null and userId != 0">user_id,</if>
<if test="deptId != null and deptId != 0">dept_id,</if>
<if test="userName != null and userName != ''">user_name,</if>
<if test="nickName != null and nickName != ''">nick_name,</if>
<if test="email != null and email != ''">email,</if>
<if test="avatar != null and avatar != ''">avatar,</if>
<if test="phonenumber != null and phonenumber != ''">phonenumber,</if>
<if test="sex != null and sex != ''">sex,</if>
<if test="password != null and password != ''">password,</if>
<if test="status != null and status != ''">status,</if>
<if test="createBy != null and createBy != ''">create_by,</if>
<if test="remark != null and remark != ''">remark,</if>
create_time
)values(
<if test="userId != null and userId != ''">#{userId},</if>
<if test="deptId != null and deptId != ''">#{deptId},</if>
<if test="userName != null and userName != ''">#{userName},</if>
<if test="nickName != null and nickName != ''">#{nickName},</if>
<if test="email != null and email != ''">#{email},</if>
<if test="avatar != null and avatar != ''">#{avatar},</if>
<if test="phonenumber != null and phonenumber != ''">#{phonenumber},</if>
<if test="sex != null and sex != ''">#{sex},</if>
<if test="password != null and password != ''">#{password},</if>
<if test="status != null and status != ''">#{status},</if>
<if test="createBy != null and createBy != ''">#{createBy},</if>
<if test="remark != null and remark != ''">#{remark},</if>
sysdate()
)
</insert>
<update id="updateUser" parameterType="SysUser">
update sys_user
<set>
<if test="deptId != null and deptId != 0">dept_id = #{deptId},</if>
<if test="userName != null and userName != ''">user_name = #{userName},</if>
<if test="nickName != null and nickName != ''">nick_name = #{nickName},</if>
<if test="email != null ">email = #{email},</if>
<if test="phonenumber != null ">phonenumber = #{phonenumber},</if>
<if test="sex != null and sex != ''">sex = #{sex},</if>
<if test="avatar != null and avatar != ''">avatar = #{avatar},</if>
<if test="password != null and password != ''">password = #{password},</if>
<if test="status != null and status != ''">status = #{status},</if>
<if test="loginIp != null and loginIp != ''">login_ip = #{loginIp},</if>
<if test="loginDate != null">login_date = #{loginDate},</if>
<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if>
<if test="remark != null">remark = #{remark},</if>
update_time = sysdate()
</set>
where user_id = #{userId}
</update>
<update id="updateUserStatus" parameterType="SysUser">
update sys_user set status = #{status} where user_id = #{userId}
</update>
<update id="updateUserAvatar" parameterType="SysUser">
update sys_user set avatar = #{avatar} where user_name = #{userName}
</update>
<update id="resetUserPwd" parameterType="SysUser">
update sys_user set password = #{password} where user_name = #{userName}
</update>
<delete id="deleteUserById" parameterType="Long">
update sys_user set del_flag = '2' where user_id = #{userId}
</delete>
<delete id="deleteUserByIds" parameterType="Long">
update sys_user set del_flag = '2' where user_id in
<foreach collection="array" item="userId" open="(" separator="," close=")">
#{userId}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,34 @@
<?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.system.mapper.SysUserPostMapper">
<resultMap type="SysUserPost" id="SysUserPostResult">
<result property="userId" column="user_id" />
<result property="postId" column="post_id" />
</resultMap>
<delete id="deleteUserPostByUserId" parameterType="Long">
delete from sys_user_post where user_id=#{userId}
</delete>
<select id="countUserPostById" resultType="Integer">
select count(1) from sys_user_post where post_id=#{postId}
</select>
<delete id="deleteUserPost" parameterType="Long">
delete from sys_user_post where user_id in
<foreach collection="array" item="userId" open="(" separator="," close=")">
#{userId}
</foreach>
</delete>
<insert id="batchUserPost">
insert into sys_user_post(user_id, post_id) values
<foreach item="item" index="index" collection="list" separator=",">
(#{item.userId},#{item.postId})
</foreach>
</insert>
</mapper>

View File

@ -0,0 +1,44 @@
<?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.system.mapper.SysUserRoleMapper">
<resultMap type="SysUserRole" id="SysUserRoleResult">
<result property="userId" column="user_id" />
<result property="roleId" column="role_id" />
</resultMap>
<delete id="deleteUserRoleByUserId" parameterType="Long">
delete from sys_user_role where user_id=#{userId}
</delete>
<select id="countUserRoleByRoleId" resultType="Integer">
select count(1) from sys_user_role where role_id=#{roleId}
</select>
<delete id="deleteUserRole" parameterType="Long">
delete from sys_user_role where user_id in
<foreach collection="array" item="userId" open="(" separator="," close=")">
#{userId}
</foreach>
</delete>
<insert id="batchUserRole">
insert into sys_user_role(user_id, role_id) values
<foreach item="item" index="index" collection="list" separator=",">
(#{item.userId},#{item.roleId})
</foreach>
</insert>
<delete id="deleteUserRoleInfo" parameterType="SysUserRole">
delete from sys_user_role where user_id=#{userId} and role_id=#{roleId}
</delete>
<delete id="deleteUserRoleInfos">
delete from sys_user_role where role_id=#{roleId} and user_id in
<foreach collection="userIds" item="userId" open="(" separator="," close=")">
#{userId}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,157 @@
<?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.system.mapper.VideoInfoMapper">
<resultMap type="VideoInfo" id="VideoInfoResult">
<result property="id" column="id"/>
<result property="sn" column="sn"/>
<result property="gateway" column="gateway"/>
<result property="cameraIndex" column="camera_index"/>
<result property="videoIndex" column="video_index"/>
<result property="type" column="type"/>
<result property="deviceType" column="device_type"/>
<result property="flyIndex" column="fly_index"/>
<result property="businessName" column="business_name"/>
</resultMap>
<sql id="selectVideoInfoVo">
select id,
sn,
gateway,
camera_index,
video_index,
type,
device_type,
fly_index,
business_name
from video_info
</sql>
<select id="selectVideoInfoList" parameterType="VideoInfo" resultMap="VideoInfoResult">
<include refid="selectVideoInfoVo"/>
<where>
<if test="sn != null and sn != ''">and sn = #{sn}</if>
<if test="gateway != null and gateway != ''">and gateway = #{gateway}</if>
<if test="cameraIndex != null and cameraIndex != ''">and camera_index = #{cameraIndex}</if>
<if test="videoIndex != null and videoIndex != ''">and video_index = #{videoIndex}</if>
<if test="type != null and type != ''">and type = #{type}</if>
<if test="deviceType != null and deviceType != ''">and device_type = #{deviceType}</if>
<if test="flyIndex != null and flyIndex != ''">and fly_index = #{flyIndex}</if>
<if test="businessName != null and businessName != ''">and business_name = #{businessName}</if>
</where>
</select>
<select id="selectVideoInfoById" parameterType="Long" resultMap="VideoInfoResult">
<include refid="selectVideoInfoVo"/>
where id = #{id}
</select>
<!-- 获取视频设备信息 -->
<select id="findVideoInfo" resultType="com.ruoyi.system.domain.VideoInfo">
select id,
sn,
gateway,
camera_index as cameraIndex,
video_index as videoIndex,
type,
device_type as deviceType,
fly_index as flyIndex,
business_name as businessName
from video_info
where sn = #{sn}
and video_index = #{videoIndex}
and type = #{type}
and gateway = #{gateway}
</select>
<!-- 根据网关获取视频设备列表信息 -->
<select id="findVideoInfoByGateway" resultType="com.ruoyi.system.domain.VideoInfo">
select id,
sn,
gateway,
camera_index,
video_index,
type,
device_type,
fly_index,
business_name
from video_info
where gateway = #{gateway}
</select>
<!-- 获取视频设备信息 -->
<select id="selectVideoByCondition" resultType="com.ruoyi.system.domain.VideoInfo">
select id,
sn,
gateway,
camera_index,
video_index,
type,
device_type,
fly_index,
business_name
from video_info
where gateway = #{gateway}
and type = #{condition}
</select>
<select id="selectGatewayByCondition" resultMap="VideoInfoResult">
select *
from video_info
where sn = #{sn} limit 1
</select>
<insert id="insertVideoInfo" parameterType="VideoInfo" useGeneratedKeys="true" keyProperty="id">
insert into video_info
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="sn != null and sn != ''">sn,</if>
<if test="gateway != null">gateway,</if>
<if test="cameraIndex != null and cameraIndex != ''">camera_index,</if>
<if test="videoIndex != null and videoIndex != ''">video_index,</if>
<if test="type != null">type,</if>
<if test="deviceType != null">device_type,</if>
<if test="flyIndex != null">fly_index,</if>
<if test="businessName != null and businessName != ''">business_name,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="sn != null and sn != ''">#{sn},</if>
<if test="gateway != null">#{gateway},</if>
<if test="cameraIndex != null and cameraIndex != ''">#{cameraIndex},</if>
<if test="videoIndex != null and videoIndex != ''">#{videoIndex},</if>
<if test="type != null">#{type},</if>
<if test="deviceType != null">#{deviceType},</if>
<if test="flyIndex != null">#{flyIndex},</if>
<if test="businessName != null and businessName != ''">#{businessName},</if>
</trim>
</insert>
<update id="updateVideoInfo" parameterType="VideoInfo">
update video_info
<trim prefix="SET" suffixOverrides=",">
<if test="sn != null and sn != ''">sn = #{sn},</if>
<if test="gateway != null">gateway = #{gateway},</if>
<if test="cameraIndex != null and cameraIndex != ''">camera_index = #{cameraIndex},</if>
<if test="videoIndex != null and videoIndex != ''">video_index = #{videoIndex},</if>
<if test="type != null">type = #{type},</if>
<if test="deviceType != null">device_type = #{deviceType},</if>
<if test="flyIndex != null">fly_index = #{flyIndex},</if>
<if test="businessName != null and businessName != ''">business_name = #{businessName},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteVideoInfoById" parameterType="Long">
delete
from video_info
where id = #{id}
</delete>
<delete id="deleteVideoInfoByIds" parameterType="String">
delete from video_info where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>