微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

HQL或Java持久性查询语言中的条款

如何解决HQL或Java持久性查询语言中的条款

您正在使用Hibernate的Query对象还是JPA?对于JPA,它应该可以正常工作:

String jpql = "from A where name in (:names)";
Query q = em.createquery(jpql);
q.setParameter("names", l);

对于Hibernate,您需要使用setParameterList:

String hql = "from A where name in (:names)";
Query q = s.createquery(hql);
q.setParameterList("names", l);

解决方法

我有以下参数化的JPA或Hibernate查询:

SELECT entity FROM Entity entity WHERE name IN (?)

我想将参数作为ArrayList 传递,这可能吗?hibernate电流告诉我,

java.lang.ClassCastException: java.util.ArrayList cannot be cast to java.lang.String

这有可能吗?

解答 :集合作为参数只能与“ :name” 这样的命名参数一起使用,而不能与“ ”这样的JDBC样式参数一起使用?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。