首页 > 编程语言 > 详细

spring boot jpa criteria api是如何生成JPQL的

时间:2019-12-06 12:42:20      阅读:79      评论:0      收藏:0      [点我收藏+]

 

当我们使用entityManager.createQuery(query)时,我们发现entityManager的注入对象如下:

技术分享图片

 

 

 

也就是它:org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean@40383b24的一个代理对象。也是一个FactoryBean.

通过这个FactoryBean就可以创建出实际代理的对象:

// Determine current EntityManager: either the transactional one
            // managed by the factory or a temporary one for the given invocation.
            EntityManager target = EntityManagerFactoryUtils.doGetTransactionalEntityManager(
                    this.targetFactory, this.properties, this.synchronizedWithTransaction);

            if (method.getName().equals("getTargetEntityManager")) {
                // Handle EntityManagerProxy interface.
                if (target == null) {
                    throw new IllegalStateException("No transactional EntityManager available");
                }
                return target;
            }

 

技术分享图片

 

 

 

最终调用的就是org.hibernate.internal.SessionImpl#createQuery(javax.persistence.criteria.CriteriaQuery<T>)

@Override
    @SuppressWarnings("unchecked")
    public <T> QueryImplementor<T> createQuery(CriteriaQuery<T> criteriaQuery) {
        checkOpen();
        try {
            return (QueryImplementor<T>) criteriaCompiler().compile( (CompilableCriteria) criteriaQuery );
        }
        catch ( RuntimeException e ) {
            throw exceptionConverter.convert( e );
        }
    }

 

compile方法的最后,可以看到:

return criteria.interpret( renderingContext ).buildCompiledQuery(
                entityManager,
                new InterpretedParameterMetadata() {
                    @Override
                    public Map<ParameterExpression<?>, ExplicitParameterInfo<?>> explicitParameterInfoMap() {
                        return explicitParameterInfoMap;
                    }

                    @Override
                    public List<ImplicitParameterBinding> implicitParameterBindings() {
                        return implicitParameterBindings;
                    }
                }
        );

 

org.hibernate.query.criteria.internal.CriteriaQueryImpl#interpret方法代码如下:

    @Override
    public CriteriaInterpretation interpret(RenderingContext renderingContext) {
        final StringBuilder jpaqlBuffer = new StringBuilder();

        queryStructure.render( jpaqlBuffer, renderingContext );

        renderOrderByClause( renderingContext, jpaqlBuffer );

        final String jpaqlString = jpaqlBuffer.toString();

        log.debugf( "Rendered criteria query -> %s", jpaqlString );
。。。。

这里就看到了JPQL了。

继续找render方法:

public void render(StringBuilder jpaqlQuery, RenderingContext renderingContext) {
        renderSelectClause( jpaqlQuery, renderingContext );

        renderFromClause( jpaqlQuery, renderingContext );

        renderWhereClause( jpaqlQuery, renderingContext );

        renderGroupByClause( jpaqlQuery, renderingContext );
    }

技术分享图片

 

spring boot jpa criteria api是如何生成JPQL的

原文:https://www.cnblogs.com/hankuikui/p/11994202.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!