字段“ user_id”没有默认值,但设置为auto_increment

时间:2019-11-12 18:08:00

标签: java mysql sql spring spring-boot

因此,我正在尝试构建一个膳食计划程序,但是当我尝试提交用户名时,会给我标题中显示的错误。我尝试向类中添加其他映射,为User类创建了一个新的存储库,但不确定为什么该程序不会像应该的那样自动递增user_ID值。

这是我讨厌的mySQL表:

CREATE TABLE `user_table` (
  `user_id` int NOT NULL AUTO_INCREMENT,
  `user_name` varchar(30),
  PRIMARY KEY (`user_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
/*!40101 SET character_set_client = @saved_cs_client */;

这是User类:

@Entity
@Table(name="user_table")
public class User {

    @Id
    @GeneratedValue(strategy= GenerationType.IDENTITY)
    @Column(name="user_ID")
    private int userID;

    @Column(name="user_name")
    private String userName;

    public User() {
        super();

        // TODO Auto-generated constructor stub
    }

    public User(int userID, String userName) {
        super();
        this.userID = userID;
        this.userName = userName;
    }

    public int getUserID() {
        return userID;
    }
    public void setUserID(int userID) {
        this.userID = userID;
    }
    public String getUserName() {
        return userName;
    }

    public void setUserName(String userName) {
        this.userName = userName;
    }

    @Override
    public String toString() {

        return "User [userID=" + userID + ", userName=" + userName + "]";
    }
}

用户类附加到的仓库:

@Repository
public interface MealPlannerRepositoryUser extends JpaRepository<User, Long>{

}

以及我的控制器类中的相关方法:

    @Autowired
    MealPlannerRepository repo;

    @Autowired
    MealPlannerRepositoryUser userRepo;

    @GetMapping("/inputUser")
    public String addNewUser(Model model) {
        User u = new User();
        Meal m = new Meal();
        model.addAttribute("newUser", u);
        model.addAttribute("newMeal", m);
        return "inputUser";
    }

    @PostMapping("/inputUser")
    public String addNewUser(@ModelAttribute User u, Meal m, Model model) {
        userRepo.save(u);
        repo.save(m);
        model.addAttribute("newUser", repo.findAll());
        model.addAttribute("newMeal", repo.findAll());
        return "results";
    }

我一定在某处缺少东西,但是我没主意了。

2 个答案:

答案 0 :(得分:1)

我不确定这是否区分大小写,但是User类中的注释@Column('user_ID')与SQL查询中的列名'user_id'不匹配。

答案 1 :(得分:1)

在实体类user_ID中与列名user_id不匹配,请在实体类user_id中进行更改