lrj
2 天以前 c61d4fe27c97d2ecc907756aa571a4ef14a7b9b6
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
package com.rongyichuang.common.repository;
 
import com.rongyichuang.common.entity.Media;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;
 
import java.util.List;
 
@Repository
public interface MediaRepository extends JpaRepository<Media, Long> {
    
    /**
     * 根据目标类型和目标ID查询媒体列表
     */
    List<Media> findByTargetTypeAndTargetIdAndState(Integer targetType, Long targetId, Integer state);
    
    /**
     * 批量查询媒体列表
     */
    List<Media> findByTargetTypeAndTargetIdInAndState(Integer targetType, List<Long> targetIds, Integer state);
    
    /**
     * 批量统计媒体数量
     */
    @Query("SELECT m.targetId, COUNT(m) FROM Media m WHERE m.targetType = :targetType AND m.targetId IN :targetIds AND m.state = :state GROUP BY m.targetId")
    List<Object[]> countByTargetTypeAndTargetIdInAndState(@Param("targetType") Integer targetType, @Param("targetIds") List<Long> targetIds, @Param("state") Integer state);
    
    /**
     * 检查ID是否存在
     */
    boolean existsById(Long id);
}