第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

使用 hibernate 與 spring data jpa 和 mysql 組合主鍵

使用 hibernate 與 spring data jpa 和 mysql 組合主鍵

有只小跳蛙 2023-06-04 11:21:23
我正在嘗試測(cè)試一個(gè)組合主鍵,不幸的是有些東西運(yùn)行不正確。包含組合主鍵的課程類@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);    }}我的測(cè)試程序private void composedPrimaryKey() {        PkCourse composedPK = new PkCourse("database", 3);        Course course = new Course(composedPK);        courseRepository.save(course);    }我的 jpa 存儲(chǔ)庫(kù)public interface CourseRepository extends JpaRepository<Course, PkCourse> {}我得到的例外原因:org.springframework.dao.InvalidDataAccessResourceUsageException:無(wú)法提取結(jié)果集;SQL [不適用];嵌套異常是 org.hibernate.exception.SQLGrammarException: 無(wú)法提取 ResultSetCaused by: java.sql.SQLSyntaxErrorException: 表 'company.course' 不存在
查看完整描述

1 回答

?
慕婉清6462132

TA貢獻(xiàn)1804條經(jīng)驗(yàn) 獲得超2個(gè)贊

如果你看看 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,這個(gè)默認(rèn)大小也依賴于你的 MySQL 版本

現(xiàn)在創(chuàng)建這樣的表的理想方法不是使用course_nameandcourse_grade作為主鍵,而是應(yīng)該使用 auuid或 auto gen id,然后將唯一索引放在course_nameand的組合上course_grade

如果您仍然遇到問(wèn)題,您還可以嘗試此答案中提到的線程中提到的不同修復(fù)方法

  1. SET @@global.innodb_large_prefix = 1;

  2. 升級(jí)到更高版本的 MySQL 5.7+

  3. set GLOBAL storage_engine='InnoDb';



查看完整回答
反對(duì) 回復(fù) 2023-06-04
  • 1 回答
  • 0 關(guān)注
  • 164 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)