我正在努力编写一个HQL查询来在表中插入新记录.我已经看到了一些插入查询,如下所示,但我不希望从另一个表插入数据,如下面的代码.
String hql = "INSERT INTO Employee(firstName,lastName,salary)" +
"SELECT firstName,salary FROM old_employee";
Query query = session.createQuery(hql);
int result = query.executeUpdate();
System.out.println("Rows affected: " + result);
最佳答案
在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();
如果您有值,实体只需致电
MyEntity e=new MyEntity();
e.setXXXX(the XXX values);
save(e);