Ошибка грамматики SQL весенней сессии [УДАЛИТЬ ИЗ SPRING_SESSION, ГДЕ EXPIRY_TIME < ?];

#spring-boot #jdbc #spring-session #oracle19c

#весенняя загрузка #jdbc #весенняя сессия #oracle19c

Вопрос:

Я использую Spring Boot 2.3.3, JDBC и Spring Session Jdbc с Oracle 19 c. Я хочу настроить свою весеннюю сессию, но я получил эту ошибку.

 ERROR 1424 --- [pool-1-thread-1] o.s.s.s.TaskUtils$LoggingErrorHandler    : Unexpected error occurred in scheduled task

org.springframework.jdbc.BadSqlGrammarException: PreparedStatementCallback; bad SQL grammar [DELETE FROM SPRING_SESSION WHERE EXPIRY_TIME < ?]; nested exception is java.sql.SQLSyntaxErrorException: ORA-00942: Table ou vue inexistante

    at org.springframework.jdbc.support.SQLErrorCodeSQLExceptionTranslator.doTranslate(SQLErrorCodeSQLExceptionTranslator.java:235) ~[spring-jdbc-5.2.8.RELEASE.jar:5.2.8.RELEASE]
    at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:72) ~[spring-jdbc-5.2.8.RELEASE.jar:5.2.8.RELEASE]
    at org.springframework.jdbc.core.JdbcTemplate.translateException(JdbcTemplate.java:1443) ~[spring-jdbc-5.2.8.RELEASE.jar:5.2.8.RELEASE]
    at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:633) ~[spring-jdbc-5.2.8.RELEASE.jar:5.2.8.RELEASE]
    at org.springframework.jdbc.core.JdbcTemplate.update(JdbcTemplate.java:862) ~[spring-jdbc-5.2.8.RELEASE.jar:5.2.8.RELEASE]
    at org.springframework.jdbc.core.JdbcTemplate.update(JdbcTemplate.java:917) ~[spring-jdbc-5.2.8.RELEASE.jar:5.2.8.RELEASE]
    at org.springframework.jdbc.core.JdbcTemplate.update(JdbcTemplate.java:927) ~[spring-jdbc-5.2.8.RELEASE.jar:5.2.8.RELEASE]
    at org.springframework.session.jdbc.JdbcIndexedSessionRepository.lambda$cleanUpExpiredSessions$8(JdbcIndexedSessionRepository.java:553) ~[spring-session-jdbc-2.3.0.RELEASE.jar:2.3.0.RELEASE]
    at org.springframework.transaction.support.TransactionTemplate.execute(TransactionTemplate.java:140) ~[spring-tx-5.2.8.RELEASE.jar:5.2.8.RELEASE]
    at org.springframework.session.jdbc.JdbcIndexedSessionRepository.cleanUpExpiredSessions(JdbcIndexedSessionRepository.java:553) ~[spring-session-jdbc-2.3.0.RELEASE.jar:2.3.0.RELEASE]
    at org.springframework.scheduling.support.DelegatingErrorHandlingRunnable.run(DelegatingErrorHandlingRunnable.java:54) ~[spring-context-5.2.8.RELEASE.jar:5.2.8.RELEASE]
    at org.springframework.scheduling.concurrent.ReschedulingRunnable.run(ReschedulingRunnable.java:93) ~[spring-context-5.2.8.RELEASE.jar:5.2.8.RELEASE]
    at java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515) ~[na:na]
    at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264) ~[na:na]
    at java.base/java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:304) ~[na:na]
    at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128) ~[na:na]
    at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628) ~[na:na]
    at java.base/java.lang.Thread.run(Thread.java:834) ~[na:na]
Caused by: java.sql.SQLSyntaxErrorException: ORA-00942: Table ou vue inexistante
  

Я попытался проверить, не ошибочны ли мои конфигурации, но я не вижу никаких ошибок

Мое приложение.свойства

 spring.datasource.url=jdbc:oracle:thin:@localhost:1521:xe
spring.datasource.username=sokida
spring.datasource.password=sokida
jasypt.encryptor.password=aLPa@@sToRm  
server.port= 5001
#Session Store
spring.session.store-type=jdbc
# Session timeout. If a duration suffix is not specified, seconds are used.

spring.session.timeout.seconds=900

# Database schema initialization mode.
spring.session.jdbc.initialize-schema=always
# Path to the SQL file to use to initialize the database schema.
spring.session.jdbc.schema=classpath:org/springframework/session/jdbc/schema-@@platform@@.sql 
# Name of the database table used to store sessions.
spring.session.jdbc.table-name=SPRING_SESSION
  

Вы найдете здесь мой pom.xml , Я добавляю зависимость от весенней сессии
Мой pom.xml

 <?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.3.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>APP</groupId>
    <artifactId>APP</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>app</name>
    <description>APPproject with spring boot</description>

    <properties>
        <java.version>11</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>



        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
            <version>RELEASE</version>
            <scope>compile</scope>
        </dependency>
        <dependency>

            <groupId>com.oracle.ojdbc</groupId>
            <artifactId>ojdbc10</artifactId>

        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-web</artifactId>
            <version>5.2.4.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <version>2.3.3.RELEASE</version>
            <scope>compile</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.session</groupId>
            <artifactId>spring-session-jdbc</artifactId>
        </dependency>


    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

  

Любая помощь, пожалуйста

Комментарии:

1. «Таблица, из которой вы пытаетесь выбрать, отсутствует» означает, что таблица (или представление), из которой вы пытаетесь выбрать, не существует. Возможно, вы подключаетесь к неправильной базе данных или неправильно написали имя таблицы?

2. Таблица @MarkRotteveel, которая не существует, связана с весенней сессией, а не с моей базой данных. spring.session.jdbc.table-name=SPRING_SESSION

3. Эта таблица должна существовать в вашей базе данных. Так что, возможно, ваше spring.session.jdbc.schema неверно.

Ответ №1:

Я пришел сюда в поисках решения этой проблемы, и комментарии очень помогают!

В моем случае проблема была связана с тем, что я обновлял свое существующее рабочее приложение с существующей базой данных с Spring Boot 1.5 до 2.4

Похоже, что новая версия ожидает другое определение таблицы, и столбец EXPIRY_TIME не существовал в моей текущей SPRING_SESSION таблице, автоматически созданный старой версией SpringBoot.

Итак, я удаляю эту таблицу, перезапускаю приложение, и таблица снова автоматически генерируется, с новыми именами столбцов, и на этот раз EXPIRY_TIME она была там.