neo4j

Módulo 5. Spring
Nivel 17 , Lección 6
Disponible

Neo4j es una base de datos de gráficos NoSQL de código abierto que utiliza un modelo de datos con todas las funciones de nodos conectados por relaciones completas, que es más adecuado para big data vinculados que los enfoques RDBMS tradicionales. Spring Boot proporciona varios asistentes para trabajar con Neo4j, incluido un spring-boot-starter-data-neo4j "inicial".

Conectarse a la base de datos Neo4j

Para acceder al servidor Neo4j, puede implementar el org.neo4j.driver.Driver autoconfigurable. De forma predeterminada, la instancia intentará conectarse al servidor Neo4j en localhost:7687 utilizando el protocolo Bolt. El siguiente ejemplo muestra cómo implementar un Driver para Neo4j, que dará acceso, entre otras cosas, a Session:

Java
import org.neo4j.driver.Driver; import org.neo4j.driver.Session; import org.neo4j.driver.Values; import org.springframework.stereotype.Component; @Component public class MyBean { private final Driver driver; public MyBean(Driver driver) { this.driver = driver; }  // ...  public String someMethod(String message) { try (Session session = this.driver.session()) { return session.writeTransaction((transaction) -> transaction .run("CREATE (a:Greeting) SET a.message = $message RETURN a.message + ', from node ' + id(a)", Values.parameters("message", message)) .single().get(0).asString()); } } } 
Kotlin
import org.neo4j.driver.Driver import org.neo4j.driver.Transaction import org.neo4j.driver.Values import org.springframework.stereotype.Component @Component class MyBean(private val driver: Driver) {  // ...  fun someMethod(message: String?): String { driver.session().use { session -> return@someMethod session.writeTransaction { transaction: Transaction -> transaction.run( "CREATE (a:Greeting) SET a.message = \$message RETURN a.message + ', from node ' + id(a)", Values.parameters("message", message) ).single()[0].asString() } } } } 

Puede agregar varios aspectos del controlador a la configuración utilizando las propiedades spring.neo4j.*. El siguiente ejemplo muestra cómo configurar el URI y las credenciales a utilizar:

Propiedades
spring.neo4j.uri=bolt://my-server:7687
spring.neo4j.authentication.username=neo4j
spring.neo4j.authentication.password=secret
Yaml
spring:
  neo4j:
    uri: "bolt://my-server:7687"
    authentication:
      username: "neo4j"
      password: "secret"

El Driver autoconfigurable se crea utilizando ConfigBuilder. Para ajustar su configuración, declare uno o más beans ConfigBuilderCustomizer. Cada uno de ellos será llamado en orden a través del ConfigBuilder, que se utiliza para crear el Driver.

Repositorios Spring Data Neo4j

Spring Data contiene soporte de repositorio para Neo4j.

Spring Data Neo4j comparte la infraestructura Spring Data JPA, al igual que muchos otros módulos Spring Data. Puede tomar el ejemplo de JPA de la sección anterior y definir City como @Node para Spring Data Neo4j en lugar de @Entity para JPA, mientras abstrae el almacenamiento funcionará exactamente como se muestra en el siguiente ejemplo:

Java
import java.util.Optional; import org.springframework.data.neo4j.repository.Neo4jRepository; public interface CityRepository extends Neo4jRepository<City, Long> { Optional<City> findOneByNameAndState(String name, String state); } 
Kotlin
import org.springframework.data.neo4j.repository.Neo4jRepository import java.util.Optional interface CityRepository : Neo4jRepository<City?, Long?> { fun findOneByNameAndState(name: String?, state: String?): Optional<City?>? } 

"Starter" spring-boot-starter-data-neo4j permite la compatibilidad con repositorios, así como la gestión de transacciones. Spring Boot admite repositorios Neo4j clásicos y reactivos a través de los beans Neo4jTemplate o ReactiveNeo4jTemplate. Si Project Reactor está disponible en el classpath, el estilo reactivo también se configura automáticamente.

Puede configurar las ubicaciones donde se buscarán repositorios y entidades usando las anotaciones @EnableNeo4jRepositories y @EntityScan, respectivamente, en un bean marcado con @Configuración código de anotación.

En una aplicación que utiliza el estilo reactivo, ReactiveTransactionManager no se configura automáticamente. Para habilitar la gestión de transacciones, se debe definir el siguiente bean en la configuración:

Java
import org.neo4j.driver.Driver; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.neo4j.core.ReactiveDatabaseSelectionProvider; import org.springframework.data.neo4j.core.transaction.ReactiveNeo4jTransactionManager; @Configuration(proxyBeanMethods = false) public class MyNeo4jConfiguration { @Bean public ReactiveNeo4jTransactionManager reactiveTransactionManager(Driver driver, ReactiveDatabaseSelectionProvider databaseNameProvider) { return new ReactiveNeo4jTransactionManager(driver, databaseNameProvider); } } 
Kotlin
import org.neo4j.driver.Driver import org.springframework.context.annotation.Bean import org.springframework.context.annotation.Configuration import org.springframework.data.neo4j.core.ReactiveDatabaseSelectionProvider import org.springframework.data.neo4j.core.transaction.ReactiveNeo4jTransactionManager @Configuration(proxyBeanMethods = false) class MyNeo4jConfiguration { @Bean fun reactiveTransactionManager(driver: Driver, databaseNameProvider: ReactiveDatabaseSelectionProvider): ReactiveNeo4jTransactionManager { return ReactiveNeo4jTransactionManager(driver, databaseNameProvider) } } 
Comentarios
TO VIEW ALL COMMENTS OR TO MAKE A COMMENT,
GO TO FULL VERSION