hibernate查询语句hql中的占位符?参数与命名参数:name设值方式搞混
2016-05-15 11:50
423 查看
先贴出异常
代码:
原因:
异常上说占位符索引越界(溢出),原因是我定义的hql中根本没有占位符“?”,我用的是命名参数,应该通过setString(paraName,paraValue)或者setParameter(paraName,paraValue)的方式来设值,我却用setParameter(int arg0, Object arg1)来设值,所以就报错了!
解决办法:
对于我这个,我通过吧:queryArgs全部替换成?的方式。
Struts has detected an unhandled exception: Messages: Position beyond number of declared ordinal parameters. Remember that ordinal parameters are 1-based! Position: 1 File: org/hibernate/engine/query/spi/ParameterMetadata.java Stacktraces org.hibernate.QueryParameterException: Position beyond number of declared ordinal parameters. Remember that ordinal parameters are 1-based! Position: 1
代码:
//定义hql
String hql = "from Book book where " + "book.bookType like :queryArgs or " + "book .bookNum like :queryArgs or " + "book.bookName like :queryArgs or " + "book.bookAuthor like :queryArgs " + "order by book.bookType, book .bookNum, book.bookAuthor, book.bookName"; //dao中设值 Query query = sessionFactory.getCurrentSession().createQuery(hql); for (int i = 0; i < objects.length; i++) { query.setParameter(i, objects[i]); }
原因:
异常上说占位符索引越界(溢出),原因是我定义的hql中根本没有占位符“?”,我用的是命名参数,应该通过setString(paraName,paraValue)或者setParameter(paraName,paraValue)的方式来设值,我却用setParameter(int arg0, Object arg1)来设值,所以就报错了!
解决办法:
对于我这个,我通过吧:queryArgs全部替换成?的方式。
相关文章推荐
- 我的视频源代码
- IO简单基础操作(一)
- HTML5新增内容
- 使用C++操作mysql数据库
- Win7下用IIS发布网站
- 检测客户端系统-PHP
- jeesite图片路径去掉“|” 只能上传单个图片
- Windows7防火墙设置简介
- Git merge 与 rebase 区别
- Android源码在线阅读网站
- scrollView
- CentOS 6.7 无线网卡wlan0配置 连接WPA加密的网络
- WebView
- 同步屏障CyclicBarrier
- 函数模板 类模板
- Dungeon Master POJ 2251
- C#做完一个网站怎么发布?
- 进度条11
- bzoj 4443: [Scoi2015]小凸玩矩阵
- Codeforces Gym 100971M Decomposition into Good Strings DP+数据结构