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

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

19.02.2016, 20:22. Показов 2328. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru