如何编写HQL插入查询?

我正在努力编写一个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”,有三个字段,如姓名,年龄,数字,我有这个用户表的实体。 什么是插入查询?

在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(); 

来自这里的第4章

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

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

HQL不支持这样的INSERT因此您必须通过创建和持久化新实体来实现此目的。

你可以在这里阅读它。

仅支持INSERT INTO … SELECT …表单。 您不能指定要插入的显式值。

你可以做:

 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。