Совместимость версии базы данных Javers - PullRequest
0 голосов
/ 04 октября 2018

Я использую

Microsoft SQL Server 2008 R2 (RTM) - 10.50.1600.1 (X64)  Enterprise Edition (64-bit) on Windows NT 6.1 <X64> (Build 7601: Service Pack 1) (Hypervisor)

Из https://docs.microsoft.com/en-us/sql/connect/jdbc/microsoft-jdbc-driver-for-sql-server-support-matrix?view=sql-server-2017, Я выбрал следующую версию драйвера JDBC:

com.microsoft.sqlserver: mssql-jdbc: 6.2.2.jre8

Среда :

org.springframework.data:spring-data-jpa:2.0.9.RELEASE
org.hibernate.javax.persistence:hibernate-jpa-2.1-api:1.0.2.Final
org.hibernate:hibernate-entitymanager:5.2.17.Final
Java version: 1.8.0_91, vendor: Oracle Corporation
OS name: "windows 10", version: "10.0", arch: "amd64", family: "windows"
org.javers:javers-spring-jpa:3.11.6

Но я получаю исключение SQLServerException: неверный синтаксис рядом с 'OFFSET' при попытке обновитьобъект, использующий

@JaversSpringDataAuditable
@Repository
public interface Users1Repository extends JpaRepository<Users1,Long>

org.polyjdbc.core.exception.QueryExecutionException: [SELECT_ERROR] Failed to run select query:
SELECT state, type, version, changed_properties, managed_type, commit_pk, author, commit_date, commit_id, g.local_id, g.fragment, g.owner_id_fk, o.local_id owner_local_id, o.fragment owner_fragment, o.type_name owner_type_name FROM jv_snapshot INNER JOIN jv_commit ON commit_pk = commit_fk INNER JOIN jv_global_id g ON g.global_id_pk = global_id_fk LEFT OUTER JOIN jv_global_id o ON o.global_id_pk = g.owner_id_fk WHERE snapshot_pk = 2200   
 ORDER BY snapshot_pk desc OFFSET 0 ROWS FETCH NEXT 1 ROWS ONLY
at org.polyjdbc.core.query.TransactionalQueryRunner.queryCollection(TransactionalQueryRunner.java:93)

Во время отладки я обнаружил, что следующий код вставляет предложение OFFSET , которое было введено в SQL Server 2012

org.polyjdbc.core.dialect.MsSqlDialectQueries.limit(Query, Limit, boolean)

Мои вопросы:

Поддерживает ли Javers SQL Server 2008 вообще?

Где взять матрицу совместимости между версиями javers и Database?

1 Ответ

0 голосов
/ 09 октября 2018

JaVers не имеют различий между версиями SQL Server, и он генерирует SQL для последней версии.Так что SQL Server 2008 не поддерживается и не будет поддерживаться.

...