Форум программистов, компьютерный форум, киберфорум
Java: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/9: Рейтинг темы: голосов - 9, средняя оценка - 4.56
215 / 63 / 25
Регистрация: 30.04.2013
Сообщений: 865
Записей в блоге: 10

Hibernate HQL UPDATE

01.03.2015, 09:04. Показов 1935. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вобщем работает ли
MySQL
1
2
3
(HQL):
 
 UPDATE Table(column1,column2) SELECT column1,column2 FROM Users  WHERE KeyColumn=5

Вобщем при нажатий в среде NetBeans
ПКМ на Проекты -> hibernate.cfg -> Выполнить запрос HQL

Вылазит окошко в котором можно делать эти самые запросы

с SELECT все норм , но вот иные запросы ,которые мне очень нужны
не рубят , в чем м/б проблема ?

В окошке транслирования запросов в SQL пишет :
'Некорректный запрос'
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.03.2015, 09:04
Ответы с готовыми решениями:

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

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

Hibernate + Cannot add or update a child row: a foreign key constraint fails
Есть вот такая схема: Соответственно два класса: @Entity @Table(name = "item_orders") public class ItemOrders implements...

14
Эксперт Java
 Аватар для KEKCoGEN
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
01.03.2015, 09:48
Qazan, обычно в update есть что-то вроде
SQL
1
UPDATE [tablename] SET [column1, column2] VALUES [val1, val2]
у вас нехватает ключевых слов. Каких именно смотрите в мануале HQL
0
215 / 63 / 25
Регистрация: 30.04.2013
Сообщений: 865
Записей в блоге: 10
01.03.2015, 09:55  [ТС]
KEKCoGEN,


Only the INSERT INTO ... SELECT ... form is supported; not the INSERT INTO ... VALUES ... form.


Цитата из сайта https://docs.jboss.org/hiberna... tch-direct
0
Эксперт Java
 Аватар для KEKCoGEN
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
01.03.2015, 10:28
Qazan, причем тут инсерт? Вы же апдейт делаете
1
215 / 63 / 25
Регистрация: 30.04.2013
Сообщений: 865
Записей в блоге: 10
01.03.2015, 10:29  [ТС]
KEKCoGEN,


Получил следующую ошибку :


org.hibernate.QueryException: query must begin with SELECT or FROM:


Добавлено через 19 секунд
KEKCoGEN, Точно

Добавлено через 1 минуту
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
        Session session = HibernateUtil.getSessionFactory().openSession();
        //Transaction tx = 
        session.beginTransaction();
        
        String hqlUpdate = "update Users c set c.firstname = :newName where c.firstname = :oldName";
        // or String hqlUpdate = "update Customer set name = :newName where name = :oldName";
        int updatedEntities = session.createQuery( hqlUpdate )
                .setString( "newName", "QQQ" )
                .setString( "oldName", "Name" )
                .executeUpdate();
        session.getTransaction().commit();
        //tx.commit();
        session.close();
в результате исполнения этого кода
0
Эксперт Java
 Аватар для KEKCoGEN
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
01.03.2015, 10:34
Qazan, попробуйте убрать с

Java
1
 String hqlUpdate = "update Users set firstname = :newName where firstname = :oldName";
1
215 / 63 / 25
Регистрация: 30.04.2013
Сообщений: 865
Записей в блоге: 10
01.03.2015, 11:04  [ТС]

Exception in thread "AWT-EventQueue-0" org.hibernate.QueryException: query must begin with SELECT or FROM: update [update users.entity.Users set firstname = :newName where firstname = :oldName]


Добавлено через 2 минуты
KEKCoGEN,

Походу понял в чем проблема
http://stackoverflow.com/quest... ql-and-sql

Добавлено через 23 минуты
Java
1
2
3
4
5
6
7
8
9
10
        Session session = HibernateUtil.getSessionFactory().openSession();
        Transaction tx = session.beginTransaction();
        
        String hqlUpdate = "update Users set firstname = :newName where firstname = :oldName";
        Query q = session.createSQLQuery(hqlUpdate )
                .setString( "newName", "QQQ" )
                .setString( "oldName", "Name" );
        q.executeUpdate();
        tx.commit();
        session.close();
Работает
0
Эксперт Java
 Аватар для KEKCoGEN
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
01.03.2015, 11:46
Qazan, тут вы создаете нативный запрос. То есть посути не пользуетесь hibernate. Это плохое решение.
0
215 / 63 / 25
Регистрация: 30.04.2013
Сообщений: 865
Записей в блоге: 10
01.03.2015, 16:21  [ТС]
KEKCoGEN, Вон он как
Ну лучше ,конечно , найти хорошее решение
значит вопрос еще открыт
0
Эксперт Java
 Аватар для KEKCoGEN
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
01.03.2015, 19:41
Qazan, покажите ваш класс ентити
0
215 / 63 / 25
Регистрация: 30.04.2013
Сообщений: 865
Записей в блоге: 10
01.03.2015, 20:04  [ТС]
KEKCoGEN,

package users.entity;
class 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
package users.entity;
// Generated 01.03.2015 4:25:26 by Hibernate Tools 4.3.1
/**
 * Users generated by hbm2java
 */
public class Users  implements java.io.Serializable {
 
 
     private String username;
     private String firstname;
     private String lastname;
     private String pass;
 
    public Users() {
    }
 
    
    public Users(String username) {
        this.username = username;
    }
    public Users(String username, String firstname, String lastname, String pass) {
       this.username = username;
       this.firstname = firstname;
       this.lastname = lastname;
       this.pass = pass;
    }
   
    public String getUsername() {
        return this.username;
    }
    
    public void setUsername(String username) {
        this.username = username;
    }
    public String getFirstname() {
        return this.firstname;
    }
    
    public void setFirstname(String firstname) {
        this.firstname = firstname;
    }
    public String getLastname() {
        return this.lastname;
    }
    
    public void setLastname(String lastname) {
        this.lastname = lastname;
    }
    public String getPass() {
        return this.pass;
    }
    
    public void setPass(String pass) {
        this.pass = pass;
    }
}
0
Эксперт Java
 Аватар для KEKCoGEN
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
01.03.2015, 20:59
похоже что-то с конфигурацией хайбернейта. Он не видит ваш класс-ентити
0
215 / 63 / 25
Регистрация: 30.04.2013
Сообщений: 865
Записей в блоге: 10
02.03.2015, 06:20  [ТС]
KEKCoGEN, но SELECT то работает
0
Эксперт Java
 Аватар для KEKCoGEN
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
02.03.2015, 09:38
Qazan, тоже верно...хз тогда...надо гуглить. Как вариант можно использовать QueryDsl. Он дает strong typing и таких проблем не возникает.
1
215 / 63 / 25
Регистрация: 30.04.2013
Сообщений: 865
Записей в блоге: 10
02.03.2015, 10:25  [ТС]
http://www.tutorialspoint.com/... amples.htm


Java
1
2
3
4
5
6
7
8
9
SessionFactory factory = new Configuration().configure().buildSessionFactory();
        Session session = factory.openSession();
        Transaction tx = session.beginTransaction();
        
        Users u = (Users)session.get(Users.class, "Admin"); 
        u.setFirstname("Qaramba");
         session.update(u); 
        
        tx.commit();
Во рубит )
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.03.2015, 10:25
Помогаю со студенческими работами здесь

HQL
Ребята,помогите со следующим заданием. Нужно вывести студентов и соответствующие им дисциплины две сущности (отношения Many...

HQL запрос
@Entity @Table(name = "tea") public class Tea implements Serializable{ @Id //@GeneratedValue(strategy =...

HQL - запросы
Здравствуйте помогите пожалуйста разобраться с HQL - я хочу сделать выборку со всей таблицы по определённому полю. Допустим есть таблица...

Ошибка при выполнении запроса hql
Всем привет! Выполняю запрос hql для получения данных и лезет ошибка: org.hibernate.QueryException: could not instantiate class from...

Struts and Hibernate ошибка: Configuration problem: Could not execute JDBC batch update
public class LoginLogic{ private Configuration cfg; private SessionFactory sf; public LoginLogic(){ try { cfg = new...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
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