我尝试使用此本机查询从表中删除行列表:
@NamedNativeQuery(name="WebGroup.DeleteIn",
query="DELETE FROM WebGroup WHERE
WebGroup.GROUP_ID IN (:IDsList)"
getEm().createNamedQuery("WebGroup.DeleteIn")
.setParameter("IDsList", groupToDeleteIDs)
.executeUpdate();
这是 MySQL 执行的 SQL:
DELETE FROM WebGroup WHERE WebGroup.GROUP_ID IN (:IDsList)
所以,JPA 不会替换变量 IDsList...
有人可以帮助我吗?
一种可行的方法是,如果您不像您尝试的那样使用 id 值,而是使用实体并让 JPA 处理它的标识,如下所示:
HashSet<Transaction> transactions = new HashSet<Transaction>();
...
entityManager.createQuery(
"DELETE FROM Transaction e WHERE e IN (:transactions)").
setParameter("transactions", new ArrayList<Transaction>(
transactions)).executeUpdate();
希望它能帮助您朝着正确的方向前进。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)