本文主要是介绍springboot+hibernate+mysql自动建表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
- 引入Maven依赖包
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
spring-boot-starter-data-jpa
中已经包含了hibernate所需要的相关依赖,所以只需要引入Jpa的依赖即可。
- 创建配置文件
在application.properties
中加一行:spring.profiles.active=dev
application-dev.properties
配置文件的内容如下:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
注意:最关键的是最后两个配置,spring.jpa.properties.hibernate.hbm2ddl.auto=update
而不是hibernate.hbm2ddl.auto=update
,使用了Jpa所以键名称需要有相应调整,否则不会自动建表
spring.jpa.properties.hibernate.hbm2ddl.auto
有几种配置:
-
create
:每次加载Hibernate时都会删除上一次生成的表,然后重新生成新表,即使两次没有任何修改也会这样执行,这就导致每次启动都是一个新的数据库,也是导致数据丢失的重要原因。 -
create-drop
:每次加载Hibernate时都会生成表,但当SessionFactory关闭时,所生成的表将自动删除。 -
update
:最常用的属性值,第一次加载Hibernate时创建数据表(前提是需要先有数据库),以后加载HIbernate时只会根据model更新,即使model已经删除了某些属性,数据表也不会随之删除字段。 -
validate
:每次加载Hibernate时都会验证数据表结构,只会和已经存在的数据表进行比较,根据model修改表结构,但不会创建新表。
具体配置可参考文章《Springboot 之 文件结构和配置文件》
- 创建Model实体类
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
注意:
1、 在主建Id上需要加注释:@Id
和@GeneratedValue(strategy = GenerationType.AUTO)
才会自动增长
2、 在需要重新设置表字段名的属性上加注释@Column(name = "字段名")
即可。
3、 在类名上添加注释:@Entity
和@Table(name = "t_user")
,t_user
是表名
- 启动项目
启动项目后在study05
数据库中将出现t_user的数据表,且存在相应的表字段。
示例代码:https://github.com/zsl131/spring-boot-test/tree/master/study05
这篇关于springboot+hibernate+mysql自动建表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!