Форум программистов, компьютерный форум, киберфорум
Java EE (J2EE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
3 / 3 / 1
Регистрация: 02.12.2016
Сообщений: 142

Сложный запрос к двум таблицам Query

31.10.2021, 20:25. Показов 1356. Ответов 1

Студворк — интернет-сервис помощи студентам
Здравствуйте,
а) Дано. Есть 3 таблицы в отношении many-to-many:
1. Работники
id Имя Фамилия
1 Иван Иванов
2 Том Круз
3 Мик Джил

2. Роли
id Роль
1 Admin
2 Intern
3 Salesperson

3. Работники_Роли
id Работник Роль
1 1 1
2 1 2
3 2 3
4 3 1

Для каждой таблицы реализован свой Entity класс и Repository класс.
б) Задача.
Мне нужно вывести название роли и количество работников, которые имеют эту роль.
role.name count
Admin 2
Intern 1
Salesperson 1

в) RoleRepository
Для своей реализации я внес изменение в класс Role, добавил @Transient count в качестве поля, для подсчета. Преподаватель не засчитал решение, т.к. нужно решить без изменения класса Role.
Хорошо, где хранить количество ролей? В каком формате можно корректно решить задачу? Даже идей новых нет, подскажите как бы вы решили.
RoleRepository.java
Java
1
2
3
4
public interface RoleRepository extends JpaRepository<Role, Long> {
    @Query(value = "SELECT new Role(rol.name, count(empl)) FROM Employee empl JOIN empl.roles rol GROUP BY rol.name")
    List<Role> getCountEmployeesByRoles();
}
Role.java
Java
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
48
49
50
51
52
53
54
55
56
57
@Entity
@Table(name = "ROLE")
public class Role implements Serializable {
    private static final long serialVersionUID = -5449326074498337967L;
    @Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "role_id_generator")
    @SequenceGenerator(name = "role_id_generator", sequenceName = "sq_role_id", allocationSize = 1)
    private Long id;
 
    @Enumerated(EnumType.STRING)
    @NaturalId
    private RoleName name;
 
    @Transient
    private Long count = 0L;  // <--- это я внес, но оно не должно быть здесь
 
    public Role() {
    }
 
    public Role(RoleName name) {
        this.name = name;
    }
 
    public Role(String name) {
        this.name = RoleName.valueOf(name);
    }
 
    public Role(RoleName name, Long count){
        this.name = name;
        this.count = count;
    }
 
    public Long getId() {
        return id;
    }
 
    public void setId(Long id) {
        this.id = id;
    }
 
    public RoleName getName() {
        return name;
    }
 
    public void setName(RoleName name) {
        this.name = name;
    }
 
    public Long getCount() {
        return count;
    }
 
    public void setCount(Long count) {
        this.count = count;
    }
 
}
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
31.10.2021, 20:25
Ответы с готовыми решениями:

Как выполнить запрос к двум таблицам?
Здравствуйте, Как правильнее сделать запрос к двум таблицам с точки зрения чистого кода и правильной архитектуры приложения. Проблема: ...

Сложный запрос на выборку из БД по 3 таблицам
Друзья, нуждаюсь в Вашей квалифицированной помощи. Пытаюсь на сайте реализовать теги к заметкам, но не знаю как сделать это правильно....

Составить сложный запрос к связанным таблицам
Здравствуйте, уважаемые форумчане! Дублирую вопрос. Пробовал в ветке баз данных, результат нулевой, а время поджало. Вчера еще надо было....

1
502 / 348 / 134
Регистрация: 14.06.2016
Сообщений: 669
31.10.2021, 21:05
Лучший ответ Сообщение было отмечено MarkSD как решение

Решение

Java
1
2
3
4
5
6
7
8
9
10
public interface RoleRepository extends JpaRepository<Role, Long> {
 
    interface IRoleCount {
        String getRole();
        Long getCount();
    }
    
    @Query(value = "SELECT rol.name as role, count(empl) as count FROM Employee empl JOIN empl.roles rol GROUP BY rol.name")
    List<IRoleCount> getCountEmployeesByRoles();
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
31.10.2021, 21:05
Помогаю со студенческими работами здесь

Запрос к двум таблицам
Добрый день! Мучаюсь с этим второй день, на форуме не нашёл решения. Мне нужно сделать запрос к mongodb на выборку данных по двум...

Запрос по двум таблицам
Здравствуйте, помогите пожалуйста составить запрос по двум таблицам, у них одинаковые (Id,name,number) и вычесть одинаковые name и...

Запрос к двум таблицам
GetAllUsersTable(0); возвращает пустой объект, что я пишу не так? var firebase = require('firebase'); var config = { ...

Запрос к двум таблицам
Такая проблемка, есть 2 таблицы: t1: c столбцами id,n2,n3,n4,n5 t2: c столбцами n0,id,d1 нужно вывести id,n2,n3,n4,n5 с й табл и d1...

Запрос к двум таблицам
Помогите исправить запрос: SELECT Sotrudnik.id_sotr, Sotrudnik.familia, Sotrudnik.imea,; Sotrudnik.otchestvo, Sotrudnik.s_pasporta,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru