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

Создание и использование своих @NamedQueries. Использование EntityManager

07.12.2013, 14:01. Показов 3110. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
Создавал классы сущностей и сессий через NetBeans генераторы кода.
Использование стандартных добавить/редактировать/удалить не вызывает проблем.

Java
1
2
3
4
@NamedQueries({
    @NamedQuery(name = "Employees.findAll", query = "SELECT e FROM Employees e"),
    @NamedQuery(name = "Employees.findById", query = "SELECT e FROM Employees e WHERE e.id = :id"),
. . .
Но я хочу создать и уметь воспользоваться таким запросом:
Java
1
@NamedQuery(name = "Employees.findLikeEmpName", query = "SELECT e FROM Employees e WHERE e.empName LIKE :empName"),
Я добавил его в список запросов в класс сущностей.
Что я должен делать дальше?
Как мне сопоставить метод в классе и эту query?
Нужно ли мне использовать EntityManager и как?

В классе сессии я создал такой метод:
Java
1
2
3
4
// Получаем пользователя по id
    public Employees get(int id){
        return em.find(Employees.class, id);
    }
Но find это простой метод в интерфейсе EM.
Я не понимаю, как используя методы EM создать свой метод который будет использовать мою query с LIKE.

Добавлено через 11 минут
Я так понимаю мне нужно сделать что-то наподобие:

Java
1
2
3
4
5
6
    public LIST<Employees> findLikeEmpName(String empName) {
 
        return em.createNamedQuery("findLikeEmpName").setParameter("empName",
                empName).getResultList();
 
    }
Добавлено через 13 минут
Точнее, вот так(почему-то не могу отредактировать):
Java
1
2
3
4
    public List findLikeEmpName(String empName) {
        return em.createNamedQuery("findLikeEmpName").setParameter("empName",
                empName).getResultList();
    }
Но мне выдает стак ошибок, заинтересовало вот это:

at com.sun.proxy.$Proxy743.findLikeEmpName( Unknown Source)
at session.__EJB31_Generated__EmployeesFaca de__Intf____Bean__.findLikeEmpName(Unkno wn Source)
Почему-то Unknown Source

Добавлено через 57 минут
Разобрался.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.12.2013, 14:01
Ответы с готовыми решениями:

Создание и использование конструкторов
Требуется создать новый класс с именем DateFour, с несколькими конструкторами, а затем протестировать созданный класс, используя...

Создание и использование API сайта
Имеется сайт написанный на Java точно( по моему с использованием Google Web tools но это не знаю точно). Мне необходимо написать десктопное...

Создание своих элементов управления и их использование
Как элементы созданный своей рукой(например кнопка,заголовок программы) вставлять в форму

4
 Аватар для animator404
99 / 99 / 12
Регистрация: 05.05.2013
Сообщений: 1,208
07.12.2013, 14:11
vvApache, напишите тогда. Мне тоже интересно
0
5 / 5 / 1
Регистрация: 08.05.2011
Сообщений: 121
07.12.2013, 14:36  [ТС]
Ну, во первых надо было обращаться к запросу полностью, включая класс. Во вторых у меня там неточность в sql запросе:

Java
1
 @NamedQuery(name = "Employees.findLikeEmpName", query = "SELECT e FROM Employees e WHERE e.empName LIKE :empName"),
И сам код вызова EM:

Java
1
2
3
4
    public List findLikeEmpName(String empName) {
        return em.createNamedQuery("Employees.findLikeEmpName").setParameter("empName",
                "%" + empName + "%").getResultList();
    }
2
 Аватар для animator404
99 / 99 / 12
Регистрация: 05.05.2013
Сообщений: 1,208
07.12.2013, 15:00
vvApache, у Вас тот Named query точно правильный?
0
5 / 5 / 1
Регистрация: 08.05.2011
Сообщений: 121
07.12.2013, 15:02  [ТС]
Цитата Сообщение от animator404 Посмотреть сообщение
vvApache, у Вас тот Named query точно правильный?
последний который я скинул, правильный, работает
ищет по подстроке имени в таблице
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.12.2013, 15:02
Помогаю со студенческими работами здесь

использование своих help в Access
Ситуация такая: После старта - доступ к формам через мою панель инструментов и моё меню, если какая либо форма активна то все 'ок' при...

Использование своих DLL в JavaScript
Я слышал что можно использовать свои dll-ки в скриптах но не знаю, как это сделать и прада ли это. Может ли кто-нить подтвердить и...

Разрешено ли использование своих аттрибутов?
Можно ли использовать свои аттрибуты для тегов, для хранения некоторых значений? Запись &lt;span class='myclass'...

Использование интерфейсов в своих проектах
Добрый вечер коллеги! Тема избита до неузнаваемости. Одно дело понять и совсем другое осознать. Осознать для чего нужны...

Использование wpa_supplicant в своих программах
Здравствуйте, коллеги! Воспользовался поиском, да ничего не нашел по интересующей теме. Собственно, прошу помощи в таком вопросе. Мне...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
моя боль
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/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru