java.sql.SQLIntegrityConstraintViolationException : Column 'library_idlibrary' cannot be null

标签 java mysql hibernate jpa orm

我在 hibernate 中建立一对多关系,但是当我尝试插入一个值时 在表中我收到异常,照片实体中的 FK 不能为空。

我的父实体:

@Table(name = "library")
@Entity
public class Book {
@OneToMany(
        fetch = FetchType.LAZY,
        mappedBy = "book",
        cascade = CascadeType.ALL,
        orphanRemoval = true
)
// setters / getters and other columns 

我的子实体

@Entity
@Table(name = "photos")
public class photos{
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "idphotos")
private int id;


@ManyToOne(cascade = CascadeType.ALL,fetch = FetchType.LAZY)
@JoinColumn(name = "library_idlibrary")
private Book book;
// other columns 

异常:

java.sql.SQLIntegrityConstraintViolationException: Column 'library_idlibrary' cannot be null
com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:115)
com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:95)
com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:122)
com.mysql.cj.jdbc.ClientPreparedStatement.executeInternal(ClientPreparedStatement.java:960)
com.mysql.cj.jdbc.ClientPreparedStatement.executeUpdateInternal(ClientPreparedStatement.java:1116)
com.mysql.cj.jdbc.ClientPreparedStatement.executeUpdateInternal(ClientPreparedStatement.java:1066)

我有 DAO 对象和 Controller 正在插入值:

Controller :

  @PostMapping( value = "/newBook",consumes = {MediaType.MULTIPART_FORM_DATA_VALUE})
public String add(@ModelAttribute("book") @Valid Book book, HttpServletResponse response, HttpServletRequest request,@RequestParam(value = "photo", required = false) List<MultipartFile> photos, @RequestParam(value = "valute",required = false) String valute,BindingResult result) {
    if (result.hasErrors()) {
        return "addBook";}

    List<entity.photos> list = new ArrayList<>();
    for (MultipartFile photo : photos) {
        File file =null;
        if (!photo.isEmpty()) {
            try {
                validateImg(photo);
                file = new File(context.getRealPath("/uploadFile/" + photo.getOriginalFilename()));
                Logger.getAnonymousLogger().info("THE PATH IS " + file.getAbsolutePath());
                FileUtils.copyInputStreamToFile(photo.getInputStream(), file);
                file.createNewFile();
            } catch (IOException ex) {
                result.reject("uk_UA", "Поганий тип");
                return "addBook";
            }
        }
        if (file != null) {
            photos ph = new photos(photo.getOriginalFilename());
            StringBuilder builder = new StringBuilder();
            builder.append(file.getAbsolutePath());
            Logger.getAnonymousLogger().info("SOMETHING HAS BROKEN IN LOGGING FILE");
            System.out.println("INSIDE ADD METHOD ");
            list.add(ph);

        } else list.add(new photos(""));
    }
    book.getPhotosList().addAll(list);
    service.add(book);

    return "redirect:/books";
}

DAO:

   public void add(Book user) {
        currentSession().save(user);
}

最佳答案

很可能您没有设置从照片到书籍的反向引用,然后您通过照片集合级联了书籍中的保留/合并操作。当您向集合添加元素时,您需要维护双方的关系。例如:

Book book = new Book();
Photo photo = new Photo();
book.addPhoto(photo);
photo.setBook(book);
//notice on the line above we set the backreference of the photo to the book.
hibernateSession.persist(book);
// now it is cascading from book to photo and it will set the foreign keys correctly.

关于java.sql.SQLIntegrityConstraintViolationException : Column 'library_idlibrary' cannot be null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54732368/

相关文章:

java - HQL - 查找属性 x 最高的实体

java - 运行 Android 应用程序时,我的设备中安装了两个应用程序

java - 使用现有的外部公钥从 ECDH 导出共享 secret

java - jetty-maven-plugin 不适用于 Maven 3

php - 无法建立与 MySQL 的连接

mysql - 我想要一个从我的数据库中删除重复条目的查询

java - .toUpperCase() 使用 spring/hibernate 破坏 CRUD Web 应用程序的“添加客户”按钮

java - 使用字符串谓词过滤流

MySQL SET IF 语句

java - 如何避免 Hibernate 中实体属性的序列化