因此,我正在尝试构建一个膳食计划程序,但是当我尝试提交用户名时,会给我标题中显示的错误。我尝试向类中添加其他映射,为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";
}
我一定在某处缺少东西,但是我没主意了。
答案 0 :(得分:1)
我不确定这是否区分大小写,但是User类中的注释@Column('user_ID')与SQL查询中的列名'user_id'不匹配。
答案 1 :(得分:1)
在实体类user_ID中与列名user_id不匹配,请在实体类user_id中进行更改