java – 如何编写HQL插入查询?

我正在努力编写一个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);

例如,我有一个表“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();

来自here secion 4

如果您有值,实体只需致电

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

相关文章

目录MySQL卸载环境查看是否已安装MySQL卸载mysql服务查看是否...
目录数据类型数据类型分类数值类型以TINYINT认识整型族有符号...
目录表的约束空属性非空约束(NOT NULL Constraint)默认值定...
目录函数时间日期函数:字符串函数数学函数其他函数 函数 时间...
目录使用C语言连接库的安装C APImysql_initmysql_real_conne...
目录用户用户管理查询所有用户查看当前用户查看当前连接数创...