首页 > 解决方案 > 数据初始化在 Spring Boot Hibernate 应用程序中不起作用

问题描述

我正在学习 spring boot 并尝试我的第一个示例应用程序,但一直坚持数据初始化。我能够创建表,但我的 data.sql 文件没有执行。以下是我的申请文件:

spring.jpa.show-sql=true
spring.h2.console.enabled=true
spring.datasource.initialization-mode=always

类别:

@Entity
@NoArgsConstructor
@Data
@Table(name="category")
public class Category {
    @Id
    private Long id;

    //Travel, Grocery,...
    private String name;

}

数据.sql:

insert into category values (1,'Travel')
insert into category values (2,'Auto Loan')
insert into category  values (3,'Travel')

控制器:

    package com.example.codeengine.expense.controller;

import java.util.Collection;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.example.codeengine.expense.model.Category;
import com.example.codeengine.expense.repository.CategoryRepository;


@RestController
@RequestMapping("/api")
public class CategoryController {
    private CategoryRepository categoryRepository;

    public CategoryController(CategoryRepository categoryRepository) {
        super();
        this.categoryRepository = categoryRepository;
    }

    @GetMapping("/categories")
    Collection<Category> categories(){
        System.out.println(categoryRepository.findAll());
        return categoryRepository.findAll();
    }
}

有人可以在这里帮助我吗?

标签: javahibernatespring-bootjpa

解决方案


您需要添加 getter-setter 来检索和设置数据。

您可以在类中手动添加 getter-setter,Category或者如果您正在使用,Lombok则需要在类级别添加注释,如下所示:

@Entity
@Getter
@Setter
@AllArgsConstructor
@NoArgsConstructor
@ToString
@Data
@Table(name="category")
public class Category {
    @Id
    private Long id;

    //Travel, Grocery,...
    private String name;

}

我为getter-setter、构造函数和 toString 方法添加了注释。


推荐阅读