jinlin
2023-11-03 35435e8b1995e6775c82b86652381e07e3faff54
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
package com.zt.modules.sys.service;
 
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.zt.common.service.BaseService;
import com.zt.modules.sys.dao.SysPostUserDao;
import com.zt.modules.sys.dto.PostDto;
import com.zt.modules.sys.model.SysPostUser;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
 
import java.util.List;
import java.util.stream.Collectors;
 
/**
 * SYS_POST_USER
 *
 * @author zt generator
 * @since 1.0.0 2020-06-11
 */
@Service
public class SysPostUserService extends BaseService<SysPostUserDao, SysPostUser> {
 
    /**
     * 根据用户ID,获取岗位ID列表
     */
    public List<PostDto> getUserPosts(Long userId) {
        return baseDao.getUserPosts(userId);
    }
 
    @Transactional(rollbackFor = Exception.class)
    public void saveOrUpdate(Long userId, List<Long> postIdList) {
        List<SysPostUser> list = postIdList.stream().map(postId -> new SysPostUser(postId, userId))
                .collect(Collectors.toList());
        this.saveRelatedDatas("user_id", userId, "post_id", list);
    }
 
    /**
     * 根据岗位id,删除岗位用户关系
     *
     * @param postId
     *            岗位id
     */
    @Transactional(rollbackFor = Exception.class)
    public void deleteByPostId(Long postId) {
        baseDao.delete(new QueryWrapper<SysPostUser>().lambda().eq(SysPostUser::getPostId, postId));
    }
}