我正在尝试测试一个组合主键,不幸的是有些东西运行不正确。包含组合主键的课程类@Entity(name = "Course")public class Course { @EmbeddedId private PkCourse pkCourse; public Course() {} public Course( PkCourse pkCourse) { this.pkCourse = pkCourse; } public PkCourse getPkCourse() { return pkCourse; } public void setPkCourse( PkCourse pkCourse ) { this.pkCourse = pkCourse; }}表示组合主键的类@Embeddablepublic class PkCourse implements Serializable { @Column(name = "courseName") private String courseName; @Column(name = "courseGrade") private Integer grade; PkCourse(){ } public PkCourse( String courseName, Integer grade ) { this.courseName = courseName; this.grade = grade; } public String getCourseName() { return courseName; } public void setCourseName( String courseName ) { this.courseName = courseName; } public Integer getGrade() { return grade; } public void setGrade( Integer grade ) { this.grade = grade; } @Override public boolean equals( Object o ) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; PkCourse pkCourse = (PkCourse) o; return courseName.equals(pkCourse.courseName) && Objects.equals(grade, pkCourse.grade); } @Override public int hashCode() { return Objects.hash(courseName, grade); }}我的测试程序private void composedPrimaryKey() { PkCourse composedPK = new PkCourse("database", 3); Course course = new Course(composedPK); courseRepository.save(course); }我的 jpa 存储库public interface CourseRepository extends JpaRepository<Course, PkCourse> {}我得到的例外原因:org.springframework.dao.InvalidDataAccessResourceUsageException:无法提取结果集;SQL [不适用];嵌套异常是 org.hibernate.exception.SQLGrammarException: 无法提取 ResultSetCaused by: java.sql.SQLSyntaxErrorException: 表 'company.course' 不存在
1 回答
慕婉清6462132
TA贡献1804条经验 获得超2个赞
如果你看看 DDL
create table course (
course_name varchar(255) not null,
course_grade integer not null,
primary key (course_name, course_grade)
) engine=MyISAM" via JDBC Statement
表中索引的值的大小有限制MyISAM
,这个默认大小也依赖于你的 MySQL 版本
现在创建这样的表的理想方法不是使用course_name
andcourse_grade
作为主键,而是应该使用 auuid
或 auto gen id
,然后将唯一索引放在course_name
and的组合上course_grade
。
如果您仍然遇到问题,您还可以尝试此答案中提到的线程中提到的不同修复方法
SET @@global.innodb_large_prefix = 1;
升级到更高版本的 MySQL 5.7+
set GLOBAL storage_engine='InnoDb';
添加回答
举报
0/150
提交
取消