Форум программистов, компьютерный форум, киберфорум
Java: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 0
Регистрация: 21.01.2016
Сообщений: 12

Hibernate, HQL. Select из таблиц с отношением many to many

19.02.2016, 20:22. Показов 2361. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет. Имеется две таблицы(Disc и Users) с отношением многие-ко-многим, связанные через третью(takenitem)через discId и userId. Не могу понять как сделать выборку, чтобы получить в результате следующие поля: disc.discname, disc.discyear, disc.genre, disc.discOwner, users.username.

Цель: вывести в jsp таблицу с данными диска и username пользователя таблицы (что хранятся в takenitem).

Users:

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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
import java.util.List;
 
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;
import javax.persistence.Table;
 
@Entity
@Table(name="users")
public class Users {
 
    @Id
    @GeneratedValue
    private Integer userId;
    
    @ManyToMany
    @JoinTable(name="takenItem"
        ,joinColumns=@JoinColumn(name="userId")
        ,inverseJoinColumns=@JoinColumn(name="discId"))
    private List<Disc> follows;
    
    @Column
    private String username;
    
    @Column
    private String password;
    
    @Column
    private String firstname;
    
    @Column
    private String lastname;
    
        @Column
    private boolean enabled=true;
        
        @Column
    private String authority="ROLE_USER";
        
    @Column
    private String email;
 
    public Integer getUserId() {
        return userId;
    }
 
    public void setUserId(Integer userId) {
        this.userId = userId;
    }
 
    public List<Disc> getFollows() {
        return follows;
    }
 
    public void setFollows(List<Disc> follows) {
        this.follows = follows;
    }
 
    public String getUsername() {
        return username;
    }
 
    public void setUsername(String username) {
        this.username = username;
    }
 
    public String getPassword() {
        return password;
    }
 
    public void setPassword(String password) {
        this.password = password;
    }
        public boolean isEnabled() {
        return enabled;
    }
 
    public void setEnabled(boolean enabled) {
        this.enabled = enabled;
    }
    public String getFirstname() {
        return firstname;
    }
 
    public void setFirstname(String firstname) {
        this.firstname = firstname;
    }
 
    public String getLastname() {
        return lastname;
    }
 
    public void setLastname(String lastname) {
        this.lastname = lastname;
    }
 
    public String getAuthority() {
        return authority;
    }
 
    public void setAuthority(String authority) {
        this.authority = authority;
    }
 
    public String getEmail() {
        return email;
    }
 
    public void setEmail(String email) {
        this.email = email;
    }
 
    
}

Disc:
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
import java.util.List;
import javax.persistence.Column;
 
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;
import javax.persistence.Table;
 
@Entity
@Table(name="disc")
public class Disc {
    @Id
    @GeneratedValue
    private Integer discId;
    
    @ManyToMany
    @JoinTable(name="takenItem"
        ,joinColumns=@JoinColumn(name="discId")
        ,inverseJoinColumns=@JoinColumn(name="userId"))
    private List<Users> followedBy;
    @Column
    private String discName;
        @Column
    private String genre;
        @Column
    private Integer discyear;
        @Column
    private String discOwner;
        @Column
        private boolean discIsFree;
 
    public boolean isDiscIsFree() {
        return discIsFree;
    }
 
    public void setDiscIsFree(boolean discIsFree) {
        this.discIsFree = discIsFree;
    }
        
    public String getDiscName() {
        return discName;
    }
 
    public void setDiscName(String discName) {
        this.discName = discName;
    }
    
    
    public String getGenre() {
        return genre;
    }
 
    public void setGenre(String genre) {
        this.genre = genre;
    }
 
    public Integer getDiscyear() {
        return discyear;
    }
 
    public void setDiscyear(Integer discyear) {
        this.discyear = discyear;
    }
 
    public Integer getDiscId() {
        return discId;
    }
 
    public void setDiscId(Integer discId) {
        this.discId = discId;
    }
 
    public List<Users> getFollowedBy() {
        return followedBy;
    }
 
    public void setFollowedBy(List<Users> followedBy) {
        this.followedBy = followedBy;
    }
 
    public String getDiscOwner() {
        return discOwner;
    }
 
    public void setDiscOwner(String discOwner) {
        this.discOwner = discOwner;
    }
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.02.2016, 20:22
Ответы с готовыми решениями:

Hibernate HQL UPDATE
Вобщем работает ли (HQL): UPDATE Table(column1,column2) SELECT column1,column2 FROM Users WHERE KeyColumn=5 Вобщем...

Hibernate (HQL): именованный запрос (NamedQuery) с конкатенацией строк внутри
Нужно сформировать запрос в котором будет два строковых поля объекта (те два столбца таблицы) соединяться и потом уже проверяться на like. ...

HQL vs SQL. Собственно какие плюсы использования HQL?
Собственно какие плюсы использования HQL? Я тут на днях столкнулся с проблемой при которой вылетает эксепшн из-за того, что hql пытается...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
19.02.2016, 20:22
Помогаю со студенческими работами здесь

Является ли это отношение отношением эквивалентности или отношением порядка?
На множестве {a,b,c} задано отношение T = { (a,a), (b,a), (a,b) (c,c) } Являются ли это отношение отношением эквивалентности или отношением...

Запрос по NativeSQL Hibernate Select count
String sql = &quot;SELECT books.genre, COUNT(*) AS count FROM books GROUP BY genre&quot;; SQLQuery query= session.createSQLQuery(sql); ...

Java hibernate обработка результата запроса SELECT
Здравствуйте. Скажите пожалуйста - какой способ обработки таблицы, сформированной из нескольких других таблиц путем SQL запроса, является...

Связка таблиц Hibernate
Добрый день, столкнулся вот с какой проблемой. У меня есть 2 сущности: Folder и File. Получается Файл может находится в какой-либо папке,...

Отношения таблиц БД в Hibernate
Добрый день, пытаюсь разобраться с Hibernate, до этого приложение было написано с использованием обычных ДАО. Структура такая, у меня...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru