Java.lang.NoSuchMethodError: javax.persistence.EntityManager.createStoredProcedureQuery (Ljava / lang / String;)

Я выполнил хранимую процедуру из JPA данных Spring, для этого я использую hibernate-jpa-2.1-api, но получаю исключение:

java.lang.NoSuchMethodError: javax.persistence.EntityManager.createNamedStoredProcedureQuery(Ljava/lang/String;)Ljavax/persistence/StoredProcedureQuery; 

Но в интерфейсе EntityManger я вижу, что этот метод объявлен как

public abstract StoredProcedureQuery createNamedStoredProcedureQuery(String 
paramString);"

Пожалуйста, помогите решить эту проблему. Ниже приведен код

@Entity
@NamedStoredProcedureQuery(name = "get_buyer_details", procedureName = "GETBUYERACCTSDTL", resultClasses= BuyerDetailsOut.class,
        parameters= {@StoredProcedureParameter(mode=ParameterMode.IN, name = "buyerId", type=String.class),
                @StoredProcedureParameter(mode=ParameterMode.IN, name = "cardNo", type=String.class),
                @StoredProcedureParameter(mode=ParameterMode.IN, name = "prodType", type=String.class),
                @StoredProcedureParameter(mode=ParameterMode.REF_CURSOR, name = "buyerDetailsOut", type=void.class)}

)
public class BuyerDetails {


@Id
private long id;


public long getId() {
    return id;
}


public void setId(long id) {
    this.id = id;
}

}

Репозиторий ::

@Repository
public interface AccountDao extends JpaRepository<BuyerDetails, Long> {

static final String AA = "get_buyer_details";
@Procedure(name=AA)
public List<BuyerDetailsOut> getBuyerDetails(@Param("buyerId") String buyerId, @Param("cardNo") String cardNo, @Param("prodType") String prodType);

}

pom.xml

<dependencies>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
        <version>${spring-boot.version}</version>
        <exclusions>
                    <exclusion>
                        <artifactId>spring-boot-starter-tomcat</artifactId>
                        <groupId>org.springframework.boot</groupId>
                    </exclusion>
                    <!--Jackson databind excluded since internally used version quarantined by IQ Nexus (CDCR-6935)-->
                    <exclusion>
                        <artifactId>jackson-databind</artifactId>
                        <groupId>com.fasterxml.jackson.core</groupId>
                    </exclusion>
                </exclusions>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
        <version>${spring-boot.version}</version>
         <exclusions>
            <exclusion>
                <groupId>org.apache.tomcat</groupId>
                <artifactId>tomcat-jdbc</artifactId>
            </exclusion>
            <exclusion>
                <groupId>org.hibernate.javax.persistence</groupId>
                <artifactId>hibernate-jpa-2.1-api</artifactId>
            </exclusion>

        </exclusions> 
    </dependency>

    <dependency>
        <groupId>org.hibernate.javax.persistence</groupId>
        <artifactId>hibernate-jpa-2.1-api</artifactId>
        <version>1.0.2.Final</version>
    </dependency>


    <dependency>
        <groupId>oracle</groupId>
        <artifactId>ojdbc6</artifactId>
        <version>${oracle.ojdbc.version}</version>
        <scope>provided</scope>
    </dependency>


    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>${junit.version}</version>
        <scope>test</scope>
    </dependency>

    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>3.0.1</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>jstl</artifactId>
        <version>1.2</version>
    </dependency>

</dependencies>

Можете ли вы подтвердить с помощью mvn dependency: tree и mvn dependency: проанализировать, что в ваших зависимостях нет конфликта?

MohammadReza Alagheband 16.09.2018 07:37

Спасибо @MohammadRezaAlagheband, в банке Hibernate-JPA были конфликты, каким-то образом были добавлены две банки с разными версиями. Теперь эта проблема решена, и я получаю еще одно исключение: «java.sql.SQLException: количество имен параметров не соответствует количеству зарегистрированных праметров». Это исключение возникает, когда я использую OUT или REF_CURSOR. Если хранимая процедура имеет только параметр IN, тогда работает нормально. Пожалуйста, предложите, как использовать это с OUT / REF_CURSOR. Спасибо

Manoj K. Ghanaksh 18.09.2018 13:44
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
2
2
611
1

Ответы 1

Пожалуйста, измените имя в NamedStoredProcedureQuery, как показано ниже, а также измените имя процедуры в репозитории, как определенное имя хранимой процедуры.

 @Entity
    @NamedStoredProcedureQuery(name = "createNamedStoredProcedureQuery", procedureName = "GETBUYERACCTSDTL", resultClasses= BuyerDetailsOut.class,
            parameters= {@StoredProcedureParameter(mode=ParameterMode.IN, name = "buyerId", type=String.class),
                    @StoredProcedureParameter(mode=ParameterMode.IN, name = "cardNo", type=String.class),
                    @StoredProcedureParameter(mode=ParameterMode.IN, name = "prodType", type=String.class),
                    @StoredProcedureParameter(mode=ParameterMode.REF_CURSOR, name = "buyerDetailsOut", type=void.class)}

    )

и внести изменения в репозиторий тоже вызовите по имени процедуры.

@Repository
public interface AccountDao extends JpaRepository<BuyerDetails, Long> {

    static final String AA = "GETBUYERACCTSDTL";
    @Procedure(name=AA)
    public List<BuyerDetailsOut> getBuyerDetails(@Param("buyerId") String buyerId, @Param("cardNo") String cardNo, @Param("prodType") String prodType);

}

Другие вопросы по теме