package com.ics.system.mapper; import com.ics.system.domain.User; import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Param; import java.util.List; import java.util.Set; /** * 用户表 数据层 * */ @Mapper public interface UserMapper { /** * 根据条件分页查询用户列表 * * @param user 用户信息 * @return 用户信息集合信息 */ List selectUserList(User user); /** * 根据条件分页查询未已配用户角色列表 * * @param user 用户信息 * @return 用户信息集合信息 */ List selectAllocatedList(User user); /** * 根据条件分页查询未分配用户角色列表 * * @param user 用户信息 * @return 用户信息集合信息 */ List selectUnallocatedList(User user); /** * 通过用户名查询用户 * * @param username 用户名 * @param type 用户类型 * @return 用户对象信息 */ User selectUserByUsername(@Param("username") String username, @Param("type") User.Type type); /** * 通过Openid查询用户 * * @param openid * @return 用户对象信息 */ User selectUserByOpenid(String openid); /** * 通过手机号码查询用户 * * @param mobile 手机号码 * @return 用户对象信息 */ User selectUserByMobile(String mobile); /** * 通过邮箱查询用户 * * @param email 邮箱 * @return 用户对象信息 */ User selectUserByEmail(String email); /** * 通过用户ID查询用户 * * @param userId 用户ID * @return 用户对象信息 */ User selectUserById(Long userId); /** * 通过用户ID删除用户 * * @param userId 用户ID * @return 结果 */ int deleteUserById(Long userId); /** * 批量删除用户信息 * * @param ids 需要删除的数据ID * @return 结果 */ int deleteUserByIds(Long[] ids); /** * 修改用户信息 * * @param user 用户信息 * @return 结果 */ int updateUser(User user); /** * 新增用户信息 * * @param user 用户信息 * @return 结果 */ int insertUser(User user); /** * 校验用户名称是否唯一 * * @param username 登录名称 * @return 结果 */ User checkUsernameUnique(String username); /** * 校验用户名称是否唯一 * * @param nickname 登录名称 * @return 结果 */ User checkNicknameUnique(String nickname); /** * 校验手机号码是否唯一 * * @param mobile 手机号码 * @return 结果 */ User checkPhoneUnique(String mobile); /** * 校验email是否唯一 * * @param email 用户邮箱 * @return 结果 */ User checkEmailUnique(String email); /** * 查询拥有当前角色的所有用户编号 * */ Set selectUserIdsHasRoles(Long[] roleIds); /** * 查询拥有当前角色的所有用户编号 * */ Set selectUserIdsInDepts(Long[] deptIds); /** * 新增app用户信息 * * @param user 用户信息 * @return 结果 */ int insertAppUser(User user); }