我在使用JPA时,使用如下查询语句:
Query query = em.createQuery(select bean from Content bean where bean.departmentId in (:departmentIds));
然后设置参数:
query.setParameter("departmentIds", departmentIds);
这个departmentIds是Integer[]型的。
程序运行时:提示 [Ljava.lang.Integer;cannot be cast to java.lang.Integer
请问大侠们,这是什么原因?

Ljava.lang.Integer;cannot be cast to java.lang.Integer:JPA查询参数设置请教
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- 疯狂的java程序员 2011-02-02 19:32关注
提示 [Ljava.lang.Integer;cannot be cast to java.lang.Integer
---表示要传进一个Integer类型,但是你传了一个Integer数组
解决
在query.setParameter("departmentIds", departmentIds); 中参数
departmentIds要手动拼接成字符串 departmentIds="1,2,3,4";本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报