web-dev-qa-db-ja.com

1つのHibernateクエリで複数の列を更新しますか?

次のHQLがあります。

String hql = "UPDATE Buchung as b " +
             "set STORNO = :Storno " +
             "where ID = :BuchungID";

HQLで複数の列を更新することは可能ですか?例えば:

String hql = "UPDATE Buchung as b " +
              "set STORNO = :Storno " +
              "set NAME = :Name " +
               ......  
              "where ID = :BuchungID";

MSSQLでそれを行う方法を知っていますが、Hibernateでそれを行う方法がわかりません。

14
Paks

この場合、HQLはSQLと同じです。列を区切るにはカンマを使用するだけです。

String hql = "UPDATE Buchung as b set " +
          "STORNO = :Storno," +
          "NAME = :Name " +
           ......  
          "where ID = :BuchungID";
28

構文はSQL構文に似ていますが、列の代わりにフィールド/プロパティがマップされています。

update Buchung set storNo = :storno, name = :name where id = :buchungID

目標が単一のエンティティインスタンスを変更することである場合は、

Buchung b = (Buchung) session.get(Buchung.class, buchungId);
b.setStorNo(newStorno);
b.setName(newName);
3
JB Nizet
    String hql = "UPDATE Buchung as b set " +
          "STORNO = :Storno," +
          "NAME = :Name " +
           ......  
          "where ID = :BuchungID";

Query qr = session.createSQLQuery(hql);

qr.setParameter("Storno","sto_value");

qr.setParameter("Name","name_value");

...

qr.executeUpdate();

通常、クエリを実行するには「トランザクション」が必要です

    Transaction transaction = null;
transaction = session.begintransaction();
...
transaction.commit();
1
dungth4