2024-10-26 16:07:35 +08:00
|
|
|
<?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="cn.iocoder.yudao.module.system.dal.mysql.permission.UserRoleMapper">
|
|
|
|
|
|
|
|
<select id="selectByRoleCode" resultType="cn.iocoder.yudao.module.system.api.user.dto.UserDTO">
|
|
|
|
SELECT
|
|
|
|
*
|
|
|
|
FROM
|
|
|
|
system_users
|
|
|
|
WHERE
|
|
|
|
id IN (
|
|
|
|
SELECT
|
|
|
|
user_id
|
|
|
|
FROM
|
|
|
|
system_user_role sur
|
|
|
|
WHERE
|
|
|
|
sur.tenant_id = #{tenantId}
|
|
|
|
AND sur.role_id = ( SELECT id FROM system_role WHERE `code` = #{roleCode} ))
|
|
|
|
</select>
|
2024-10-29 15:13:47 +08:00
|
|
|
<select id="selectListByRoleId" resultType="cn.iocoder.yudao.module.system.api.user.dto.UserDTO"
|
|
|
|
parameterType="cn.iocoder.yudao.module.system.controller.admin.permission.vo.role.RolePageReqVO">
|
2025-02-19 18:02:39 +08:00
|
|
|
select distinct su.*,GROUP_CONCAT(DISTINCT sr2.name SEPARATOR ',') AS roleNames
|
2024-11-18 17:19:40 +08:00
|
|
|
from system_users su
|
|
|
|
left join system_user_role sr on su.id = sr.user_id
|
2024-10-29 15:13:47 +08:00
|
|
|
left join system_role sr2 on sr.role_id = sr2.id
|
|
|
|
<where>
|
2024-12-19 17:48:24 +08:00
|
|
|
su.deleted = 0 and sr2.service_package_id = 'jiance' and sr2.code != 'jcyh'
|
2025-02-21 16:42:37 +08:00
|
|
|
|
2024-10-29 15:13:47 +08:00
|
|
|
<if test="role.nickname != null">
|
2025-01-22 17:55:40 +08:00
|
|
|
and (su.nickname like CONCAT('%',#{role.nickname},'%') OR su.username like CONCAT('%',#{role.nickname},'%'))
|
2024-10-29 15:13:47 +08:00
|
|
|
</if>
|
|
|
|
</where>
|
2025-02-19 18:02:39 +08:00
|
|
|
group by su.id
|
2025-02-21 16:42:37 +08:00
|
|
|
<if test="role.roleId != null">
|
|
|
|
HAVING SUM(sr.role_id = #{role.roleId}) > 0
|
|
|
|
</if>
|
|
|
|
|
2025-02-19 18:02:39 +08:00
|
|
|
order by su.nickname
|
2024-10-29 15:13:47 +08:00
|
|
|
</select>
|
2025-05-26 15:28:27 +08:00
|
|
|
|
|
|
|
<select id="selectListByRoleIdJX" resultType="cn.iocoder.yudao.module.system.api.user.dto.UserDTO"
|
|
|
|
parameterType="cn.iocoder.yudao.module.system.controller.admin.permission.vo.role.RolePageReqVO">
|
|
|
|
select
|
|
|
|
su.id,
|
|
|
|
su.username,
|
|
|
|
su.nickname,
|
|
|
|
su.user_type,
|
|
|
|
su.remark,
|
|
|
|
su.dept_id,
|
|
|
|
su.mobile,
|
|
|
|
su.password,
|
|
|
|
su.sex,
|
|
|
|
su.open_id,
|
|
|
|
su.tenant_id,
|
|
|
|
su.status,
|
|
|
|
COALESCE(dsc.image, su.avatar) AS avatar,
|
|
|
|
GROUP_CONCAT(DISTINCT sr2.name SEPARATOR ',') AS roleNames
|
|
|
|
from system_users su
|
|
|
|
left join system_user_role sr on su.id = sr.user_id and sr.deleted = 0
|
|
|
|
left join system_role sr2 on sr.role_id = sr2.id
|
|
|
|
INNER JOIN drive_school_coach dsc ON dsc.user_id = su.id
|
|
|
|
<where>
|
|
|
|
su.deleted = 0 and sr2.service_package_id = 'jiaxiao'
|
|
|
|
|
|
|
|
<if test="role.nickname != null">
|
|
|
|
and (su.nickname like CONCAT('%',#{role.nickname},'%') OR su.username like
|
|
|
|
CONCAT('%',#{role.nickname},'%'))
|
|
|
|
</if>
|
|
|
|
</where>
|
|
|
|
group by su.id
|
|
|
|
<if test="role.roleId != null">
|
|
|
|
HAVING SUM(sr.role_id = #{role.roleId}) > 0
|
|
|
|
</if>
|
|
|
|
|
|
|
|
order by su.nickname
|
|
|
|
</select>
|
|
|
|
|
2024-11-07 15:15:49 +08:00
|
|
|
<select id="userCodes" resultType="cn.iocoder.yudao.module.system.api.user.dto.UserRoleDTO">
|
|
|
|
SELECT
|
2025-02-27 13:15:37 +08:00
|
|
|
su.id AS userId,sr.code AS roleCode,sr.id AS roleId, sr.service_package_id
|
2024-11-07 15:15:49 +08:00
|
|
|
FROM
|
|
|
|
system_users su
|
|
|
|
LEFT JOIN system_user_role sur ON su.id = sur.user_id AND sur.deleted = 0
|
|
|
|
LEFT JOIN system_role sr ON sur.role_id = sr.id AND sr.deleted = 0
|
|
|
|
WHERE su.deleted = 0
|
|
|
|
AND su.id IN
|
|
|
|
<foreach item="item" collection="userIds" open="(" separator="," close=")">
|
|
|
|
#{item}
|
|
|
|
</foreach>
|
|
|
|
</select>
|
2024-11-09 10:57:53 +08:00
|
|
|
<select id="selectByRoleId" resultType="cn.iocoder.yudao.module.system.api.user.dto.UserDTO">
|
|
|
|
SELECT
|
|
|
|
*
|
|
|
|
FROM
|
|
|
|
system_users
|
|
|
|
WHERE
|
|
|
|
id IN (
|
|
|
|
SELECT
|
|
|
|
user_id
|
|
|
|
FROM
|
|
|
|
system_user_role sur
|
|
|
|
WHERE
|
|
|
|
sur.role_id = #{roleId})
|
|
|
|
</select>
|
2024-11-25 16:46:51 +08:00
|
|
|
<select id="selectByRoleIds" resultType="cn.iocoder.yudao.module.system.api.user.dto.UserDTO">
|
|
|
|
SELECT
|
|
|
|
*
|
|
|
|
FROM
|
|
|
|
system_users
|
|
|
|
WHERE
|
|
|
|
id IN (
|
|
|
|
SELECT
|
|
|
|
user_id
|
|
|
|
FROM
|
|
|
|
system_user_role sur
|
|
|
|
WHERE
|
|
|
|
sur.role_id IN
|
|
|
|
<foreach item="item" collection="roleIds" open="(" separator="," close=")">
|
|
|
|
#{item}
|
|
|
|
</foreach>
|
|
|
|
)
|
|
|
|
</select>
|
2025-02-10 17:59:53 +08:00
|
|
|
<select id="selectByRoleCodes" resultType="cn.iocoder.yudao.module.system.api.user.dto.UserDTO">
|
|
|
|
SELECT
|
|
|
|
*
|
|
|
|
FROM
|
|
|
|
system_users
|
|
|
|
WHERE
|
|
|
|
id IN (
|
|
|
|
SELECT
|
|
|
|
user_id
|
|
|
|
FROM
|
|
|
|
system_user_role sur
|
|
|
|
WHERE
|
|
|
|
sur.role_id IN (
|
|
|
|
SELECT
|
|
|
|
id
|
|
|
|
FROM
|
|
|
|
system_role
|
|
|
|
WHERE
|
|
|
|
code IN
|
|
|
|
<foreach item="item" collection="codes" open="(" separator="," close=")">
|
|
|
|
#{item}
|
|
|
|
</foreach>
|
|
|
|
) AND sur.deleted = 0
|
|
|
|
) AND deleted = 0
|
|
|
|
</select>
|
2024-10-26 16:07:35 +08:00
|
|
|
</mapper>
|