@NotNull注释在架构生成中不会转换为非null约束

时间:2018-07-10 05:54:54

标签: java hibernate hibernate-validator hibernate-5.x mysql-5.5

根据休眠验证器参考文档- 11.1.1节。数据库架构级别的验证https://docs.jboss.org/hibernate/stable/validator/reference/en-US/html_single/#validator-checkconstraints-db

  

开箱即用,Hibernate ORM将转换您具有的约束   为您的实体定义到映射元数据。例如,如果   实体的属性被注释为@NotNull,其列将为   在由Hibernate ORM生成的DDL模式中声明为非null。

但是,当我使用@NotNull注释字段时,不会自动获得架构级别的约束。

我尝试将Environment.HBM2DDL_AUTO设置为updatecreate,但是没有人能产生数据库约束。

即使默认情况下休眠状态下,hibernate.validator.apply_to_ddl设置为true,我什至尝试手动设置-

settings.put("hibernate.validator.apply_to_ddl", true);

但是这些选项似乎都不适合我。

我的域名课程

package com.praveen.domain;

import javax.persistence.Entity;
import javax.validation.constraints.NotNull;

import lombok.Data;

@Entity
@Data
public class Stakeholder extends MyPersistent {

    @NotNull
    private String clientCode;

    @NotNull
    private String gender;
}

MyPersistent类

package com.praveen.domain;

import java.io.Serializable;

import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.MappedSuperclass;

import lombok.Getter;
import lombok.Setter;

@MappedSuperclass
@Getter
@Setter
public class MyPersistent implements Serializable {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
}

我用来获取会话工厂的代码是

    private static SessionFactory getSessionFactory() {
        if (sessionFactory == null) {
            try {
                StandardServiceRegistryBuilder registryBuilder = new StandardServiceRegistryBuilder();

                Map<String, Object> settings = new HashMap<>();
                settings.put(Environment.DRIVER, Driver.class.getName());
                settings.put(Environment.URL, "jdbc:mysql://localhost:3306/hibernate_test?"
                        + "zeroDateTimeBehavior=CONVERT_TO_NULL&"
                        + "createDatabaseIfNotExist=true&"
                        + "useSSL=true&"
                        + "verifyServerCertificate=false&"
                        + "autoReconnect=true");
                settings.put(Environment.USER, "root");
                settings.put(Environment.PASS, "");
                settings.put(Environment.DIALECT, MySQL55Dialect.class);
                settings.put(Environment.HBM2DDL_AUTO, "update");
                settings.put(Environment.SHOW_SQL, false);

                // HikariCP settings
                settings.put("hibernate.hikari.connectionTimeout", "20000");
                settings.put("hibernate.hikari.minimumIdle", "5");
                settings.put("hibernate.hikari.maximumPoolSize", "20");
                settings.put("hibernate.hikari.idleTimeout", "300000");

                registryBuilder.applySettings(settings);
                registry = registryBuilder.build();
                MetadataSources sources = new MetadataSources(registry);
                sources.addAnnotatedClass(Stakeholder.class);

                Metadata metadata = sources.getMetadataBuilder().build();
                sessionFactory = metadata.getSessionFactoryBuilder().build();
            } catch (Exception e) {
                e.printStackTrace();
                shutdown();
            }
        }
        return sessionFactory;
    }

2 个答案:

答案 0 :(得分:1)

您应该使用 @Column(nullable = false)

@NotNull用于Bean验证,不用于架构约束,并且如果您使用的是较早版本的休眠,则@NotNull不会转换为列约束

答案 1 :(得分:1)

这对我来说是一个愚蠢的错误,因为我没有在pom.xml中包含javax.el依赖及其实现。

足够有趣的是,那时我还没有收到java.lang.NoClassDefFoundError: javax/el/ELManager错误,因为我没有编写任何代码来ValidatorFactory初始化Validation.buildDefaultValidatorFactory()

编写代码并使用ValidatorFactory后,我得到了NoClassDefFoundError,发现我缺少了javax.el依赖项。

因此最终,我可以通过添加以下依赖项来解决模式生成中的NoClassDefFoundError错误以及验证注释对数据库约束的非翻译问题。

    <dependency>
        <groupId>javax.el</groupId>
        <artifactId>javax.el-api</artifactId>
        <version>3.0.0</version>
    </dependency>

    <dependency>
        <groupId>org.glassfish</groupId>
        <artifactId>javax.el</artifactId>
        <version>3.0.0</version>
    </dependency>