如何编写HQL插入查询?

时间:2015-09-18 13:48:20

标签: java mysql hibernate

我正在努力编写一个HQL查询,以便在表中插入新记录。我已经看到了一些插入查询,如下所示,但我不希望从另一个表中插入数据,如下面的代码。

String hql = "INSERT INTO Employee(firstName, lastName, salary)"  + 
             "SELECT firstName, lastName, salary FROM old_employee";
Query query = session.createQuery(hql);
int result = query.executeUpdate();
System.out.println("Rows affected: " + result);

例如,我有一个表“User”,有三个字段,如姓名,年龄,数字,我有这个用户表的实体。什么是插入查询?

3 个答案:

答案 0 :(得分:5)

在HQL中,仅支持INSERT INTO ... SELECT ...;没有INSERT INTO ... VALUES。 HQL仅支持从另一个表插入。

因此可以像这样查询来自SELECT的INSERT

Query query = session.createQuery("insert into Stock(stock_code, stock_name)" +
                "select stock_code, stock_name from backup_stock");
int result = query.executeUpdate();

来自here secion 4

如果你有值,实体只需要调用

MyEntity e=new MyEntity();
e.setXXXX(the XXX values);
save(e);

答案 1 :(得分:3)

HQL不支持此类INSERT,因此您必须通过创建和保留新实体来执行此操作。

您可以阅读here

  

仅支持INSERT INTO ... SELECT ...表单。您无法指定要插入的显式值。

答案 2 :(得分:-1)

你可以这样做:

Foo foo = new Foo(any, columns, you, want);
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();

session.save(foo); //Here you have the magic

session.getTransaction().commit();
session.close();

只需确保将所有值设置为“not null”,否则会出现nullException。