刚开始学习,第一次使用 JPA。
按照 spring 官网的 Guides 搭建了一个项目。
引用了 JPA 和 MYSQL
dependencies {
implementation('org.springframework.boot:spring-boot-starter-data-jpa')
implementation('org.springframework.boot:spring-boot-starter-data-rest')
implementation('org.springframework.boot:spring-boot-starter-web')
runtimeOnly('mysql:mysql-connector-java')
testImplementation('org.springframework.boot:spring-boot-starter-test')
}
创建了实体类,同时在 mysql 里创建了对应的表。
@Entity
@Table(name = "demo")
public class Demo {
@Id
@GeneratedValue(strategy= GenerationType.AUTO)
private Long id;
private String name;
private String loginname;
private String loginpwd;
protected Demo(){}
public Demo(String name, String loginname, String loginpwd) {
this.name = name;
this.loginname = loginname;
this.loginpwd = loginpwd;
}
}
启动的时候报"Table 'DATABASE.hibernate_sequence' doesn't exist"的错误。
经过了解,我认为是实体类 @GenerateValue 设置的原因,应该是 GenerationType.AUTO 实际设置的类型是 TABLE,Spring 使用的 JPA 实现生成一个 hibernate_sequences 表,因为这个表不存在所以报错了。
把"strategy= GenerationType.AUTO"改成"GenerationType.IDENTITY"是可以解决
不过我现在有这么几个问题:
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.