Проверка бина не работает весенние данные neo4j

Я использую SDN со встроенным neo4j. я должен использовать проверку bean, но он не работает. null сохраняется в базе данных без каких-либо исключений.

Зависимость

dependencies {
    // specify dependencies here under either 'build', 'compile', 'runtime', 'test' or 'provided' scopes e.g.
    // runtime 'mysql:mysql-connector-java:5.1.29'
    // runtime 'org.postgresql:postgresql:9.3-1101-jdbc41'
    test "org.grails:grails-datastore-test-support:1.0-grails-2.4"
    compile 'org.springframework.data:spring-data-neo4j:3.2.0.RELEASE'
    compile 'org.hibernate:hibernate-validator:4.3.1.Final'
    compile 'javax.validation:validation-api:1.0.0.GA'      
}

xml config is 

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:neo4j="http://www.springframework.org/schema/data/neo4j"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/data/neo4j
http://www.springframework.org/schema/data/neo4j/spring-neo4j.xsd">
<context:component-scan base-package="neo4j"></context:component-scan>
<neo4j:config
storeDirectory="target/db2"
base-package="neo4j"/>

<bean id="validator"
class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean"/>

<neo4j:repositories base-package="neo4j" />
</beans>

класс сущности

@NodeEntity
class Role {
    @GraphId Long graphId

    @NotNull
    String name;

}

контроллер

@Transactional
    def saveUser(){

        println "in saveUser"
        Role role = new Role();
        Neo4jTemplate.save(role);

    }

Я использую spring-data-neo4j 3.2.0.RELEASE.


person Prabjot Singh    schedule 30.10.2014    source источник
comment
использует правильную аннотацию из validations-api?   -  person Michael Hunger    schedule 01.11.2014
comment
да, я импортировал javax.validation.constraints.NotNull;   -  person Prabjot Singh    schedule 01.11.2014
comment
Можете ли вы протестировать другое ограничение, такое как NotEmpty или Max или около того?   -  person Michael Hunger    schedule 03.11.2014
comment
да, я пробовал максимальную проверку, все еще не работает   -  person Prabjot Singh    schedule 03.11.2014
comment
я пробовал даже этот org.hibernate.validator.constraints.NotEmpty; но не удачно. Я создаю приложение Grails, есть ли с ним проблемы?   -  person Prabjot Singh    schedule 03.11.2014
comment
У меня такая же проблема   -  person alexanoid    schedule 01.03.2015


Ответы (1)


Введение

????В Spring Data Neo4j 6.x (тот, который вы используете для импорта spring-boot-starter-parent:2.4.x) удалена возможность создания ограничений непосредственно из модели предметной области .

Теперь это означает, что вы должны использовать язык запросов Neo4j Cypher и выполнить то, что вы хотите сделать (например: CREATE CONSTRAINT notnull_name IF NOT EXISTS ON (role:Role) ASSERT EXISTS (role.name) ).

Очевидно, что этим трудно управлять, так как вам придется выполнить сценарий до запуска вашего приложения. И это сложно для производственных сред.

????Итак, был создан Liquigraph: это инструмент, который выполняет , для нас скрипты.

Механизм следующий, и я сообщаю об этой проблеме на Github, которая хорошо все объясняет.


Решение

???? зависимости Pom.xml:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
    <groupId>org.neo4j</groupId>
    <artifactId>neo4j-jdbc-driver</artifactId>
    <version>4.0.1</version>
</dependency>
<dependency>
    <groupId>org.liquigraph</groupId>
    <artifactId>liquigraph-spring-boot-starter</artifactId>
    <version>4.0.2</version>
</dependency>

???? файл changelog.xml (находится здесь -> {project_dir}/src/main/resources/db/liquigraph/changelog.xml):

<?xml version="1.0" encoding="UTF-8"?>
<changelog xmlns="http://www.liquigraph.org/schema/1.0/liquigraph.xsd">
    <changeset id="constraints" author="you">
        <query>CREATE CONSTRAINT notnull_name IF NOT EXISTS ON (role:Role) ASSERT EXISTS (role.name)</query>
    </changeset>
</changelog>

???? Свойства application.yml:

spring:
  neo4j:
    uri: neo4j://localhost:7687                           #neo4j+s if you use an HTTPS Neo4j instance
    authentication:
      username: neo4j
      password: neo4j
  datasource:                                             #Liquigraph configuration used by Liquigraph POM dependency
    url: jdbc:neo4j:neo4j://localhost?encryption=false    #encryption=true if you use an HTTPS Neo4j instance
    driver-class-name: org.neo4j.jdbc.boltrouting.BoltRoutingNeo4jDriver
    username: neo4j
    password: neo4j

✔️ ## При запуске будут созданы следующие ограничения ##

Конкретные журналы:

2021-01-12 18:33:18.917  INFO 2420 --- [           main] com.zaxxer.hikari.HikariDataSource       : HikariPool-1 - Starting...
2021-01-12 18:33:18.940  INFO 2420 --- [           main] Driver                                   : Routing driver instance 706067443 created for server address localhost:7687
2021-01-12 18:33:21.510  INFO 2420 --- [           main] com.zaxxer.hikari.HikariDataSource       : HikariPool-1 - Start completed.
2021-01-12 18:33:22.672  INFO 2420 --- [           main] o.l.core.io.ChangelogGraphWriter         : Executing postcondition of changeset ID constraints by you
2021-01-12 18:33:22.775  INFO 2420 --- [           main] o.l.core.io.ChangelogGraphWriter         : Changeset ID constraints by you was just executed

Как видите, ваш файл changelog.xml был применен ✔️.

person Paolo De Dominicis    schedule 12.01.2021
comment
как я могу сделать это, используя org.springframework.boot:spring-boot-starter-data-neo4j? я все еще должен просто вытащить все 3 из этих зависимостей сверху? - person Daniel Jeney; 04.02.2021
comment
@DanielJeney да! Я использую эту самую зависимость; затем я применил эти другие 3 сверху :) - person Paolo De Dominicis; 08.02.2021