码迷,mamicode.com
首页 > 其他好文 > 详细

@table注解详解

时间:2019-12-19 19:09:23      阅读:580      评论:0      收藏:0      [点我收藏+]

标签:term   清空   tom   app   强制   entity   直接   验证   就会   

1.@table和@entity注解的区别

@entity当实体类名和表名相同,实体属性和表字段相同时,会默认完成实体属性和表字段的映射,当表名和实体类名不同,表字段和实体属性不同时,需要使用@table和@column注解完成实体和表直接的映射

2.@table注解默认的情况下只会完成表和实体之间的映射,但是当在application,yml文件中填加了配置之后就会创建表并完成映射

3.application.yml的配置

技术图片

jpa:
  hibernate:
ddl-auto 的几个常用属性值:
none:默认值,什么都不做,每次启动项目,不会对数据库进行任何验证和操作
create:每次运行项目,没有表会新建表,如果表内有数据会被清空
create-drop:每次程序结束的时候会清空表
update:每次运行程序,没有表会新建表,但是表内有数据不会被清空,只会更新表结构。
validate:运行程序会校验数据与数据库的字段类型是否相同,不同会报错
实际项目中 update 用的多一点,因为它只更新对象关系的变化,不会清空数据或者重建表。

需要注意的是,如果你不打算在设计表的时候强制加表级别的外键关系约束,就自己手动建表,然后不设置 jpa.hibernate.ddl-auto 或者设置它的值为 none。

因为使用 update 更新表,每次启动 @OneToOne、@OneToMany 等注解会检查表的外键关系,然后强制建立表外键约束,这个很烦人。
 

@table注解详解

标签:term   清空   tom   app   强制   entity   直接   验证   就会   

原文地址:https://www.cnblogs.com/wang66a/p/12069282.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!