JPA不同版本setParamer参数初始position不同的问题

 

老版本:(1)createQuery的参数在设置的时候i=0,所以position默认从1开始

类:public class QueryImpl<X> extends AbstractQueryImpl<X>
		implements TypedQuery<X>, HibernateQuery, org.hibernate.ejb.HibernateQuery

方法:	private void extractParameterInfo(Map<String, Class> namedParameterTypeRedefinition) 


142行:registerParameter( new ParameterRegistrationImpl( this, query, i + 1, javaType ) );} 

                 (2)setParamer的时候要从1开始,会比较position的位置

类:public abstract class BaseQueryImpl implements Query

方法:protected <X> ParameterRegistration<X> findParameterRegistration(int parameterPosition) 

497行:if ( parameterPosition == param.getPosition() ) {
					return (ParameterRegistration<X>) param;
				}

 

 

java.lang.IllegalArgumentException: Parameter with that position [0] did not exist
    at org.hibernate.jpa.spi.BaseQueryImpl.findParameterRegistration(BaseQueryImpl.java:502)
    at org.hibernate.jpa.spi.BaseQueryImpl.setParameter(BaseQueryImpl.java:692)
    at org.hibernate.jpa.spi.AbstractQueryImpl.setParameter(AbstractQueryImpl.java:181)
    at org.hibernate.jpa.spi.AbstractQueryImpl.setParameter(AbstractQueryImpl.java:32)

 

 

 

新版本   不能从1开始

AbstractSharedSessionContract.createQuery    final QueryImpl query = new QueryImpl(this,getQueryPlan( queryString, false ).getParameterMetadata(),queryString);

getParameterMetadata   会返回parameterMetadata.getOrdinalParametersZeroBasedCopy();//获取基于0开始的参数拷贝

设置为1这里会抛出异常,因为不是基于0开始了

ParameterMetadata的实现类为ParameterMetadataImpl

java.lang.IllegalArgumentException: Unknown parameter position: 1
    at org.hibernate.query.internal.QueryParameterBindingsImpl.getBinding(QueryParameterBindingsImpl.java:240)
    at org.hibernate.query.internal.AbstractProducedQuery.setParameter(AbstractProducedQuery.java:503)
    at org.hibernate.query.internal.AbstractProducedQuery.setParameter(AbstractProducedQuery.java:104)
    at cn.anycall.base.dao.impl.BaseDAOImpl.query(BaseDAOImpl.java:84)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值