переход от оракула sql к couchBase db просто путем изменения соединения - PullRequest
0 голосов
/ 11 октября 2018

У меня есть приложение Spring mvc, которое работает на сервере Oracle, в настоящее время я использую Spring JPA для хранения и извлечения данных.Могу ли я перейти с oracle sql на сервер couchbase, просто изменив источник данных? Если да, как настроить источник данных для работы с couchbase? Определение bean-компонента выглядит следующим образом:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:jdbc="http://www.springframework.org/schema/jdbc"
xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:jpa="http://www.springframework.org/schema/data/jpa"
xsi:schemaLocation="http://www.springframework.org/schema/jdbc      http://www.springframework.org/schema/jdbc/spring-jdbc-3.1.xsd
    http://www.springframework.org/schema/beans     http://www.springframework.org/schema/beans/spring-beans.xsd
    http://www.springframework.org/schema/tx/   http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
    http://www.springframework.org/schema/context   http://www.springframework.org/schema/context/spring-context.xsd
    http://www.springframework.org/schema/mvc   http://www.springframework.org/schema/mvc/spring-mvc.xsd
    http://www.springframework.org/schema/data/jpa  http://www.springframework.org/schema/data/jpa/spring-jpa-1.2.xsd
    http://www.springframework.org/schema/tx  http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">


<context:component-scan base-package="org.test.project"></context:component-scan>
<context:property-placeholder location="classpath:application.properties" ></context:property-placeholder>

<jpa:repositories base-package="org.test.project"
    entity-manager-factory-ref="entityManagerFactoryBean"></jpa:repositories>

<bean id="dbClassImpl" class="org.test.project.DbClassImpl" />


<!--EntityManagerFactory -->
<bean id="entityManagerFactoryBean"
    class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="packagesToScan" value="org.test.project" />
    <property name="jpaVendorAdapter">
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter" >
        <property name="showSql" value="true"/>
        </bean>
    </property>
    <property name="jpaProperties">
        <props>
            <prop key="hibernate.hbm2ddl.auto">update</prop>
            <prop key="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</prop>
        </props>
    </property>
</bean>


<bean id="dataSource"
    class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
    <property name="url" value="someurl" />
    <property name="username" value="username" />
    <property name="password" value="password" />
</bean>


<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
    <property name="entityManagerFactory" ref="entityManagerFactoryBean" />
</bean>

<tx:annotation-driven proxy-target-class="true" />

1 Ответ

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

Вот официальная документация об этом https://docs.spring.io/spring-data/couchbase/docs/current/reference/html/#configuration-xml

Однако вам нужно будет изменить несколько дополнительных вещей, чтобы он работал:

1 - одно из основных преимуществ DocumentБазы данных, чтобы избежать ненужных объединений.Если вы просто перейдете от реляционного к документу, не изменив модель, вы не получите большую ее часть.(https://blog.couchbase.com/json-data-modeling-rdbms-users/)

2 - Couchbase пока не поддерживает LocaDateTime / ZonnedDateTime, вам нужно написать конвертер.

3 - в ваших репозиториях должно быть несколько дополнительных аннотаций (https://blog.couchbase.com/couchbase-spring-boot-spring-data/)

4 - Если вы используете JPQL, вам нужно немного изменить его, чтобы использовать синтаксис N1QL (https://docs.spring.io/spring-data/couchbase/docs/current/reference/html/#couchbase.repository.n1ql)

...