后端的jpa学习

2017-04-01  本文已影响0人  一米押金

接收到这个任务,说实话作为零基础的我压力很大很紧张,不知道从哪里下手,很多东西都是看不懂的内容,就好像需要翻译官来翻译一下,不知道怎么动笔下手去写,今天把这一个工作日看的jpa的心得体会写一下,要是有不全的,希望看到的多指正。(在看jpa的时候,单元测试环节是完全没看懂的,所以只能后续再说了)

创建实体bean

这个事情,我个人理解就是,创建了一个表,这个创建表的方式,其实是我创建了一个模型,方法就是声明,比方说我创建了一个person模型,想让他成为映射实体,是数据库里的一个表的做法:

@Entity
@Table(name="demo")
public class person{
}

这句话就是创建了一个实体,然后针对这个实体建了一个名为demo的表

针对实体的属性标注:可以标注在字段上,也可以标注在属性的get方法,一般情况下就是参考后者,如例子:

@Id
@column(name="todoid_",length=10,nullable=false)
@GeneratedValue(strategy=GenerateType.auto)
public String getId(){}

这里的含义就是 1.这个id是主键
2.这个id的字段名为"todoid",长度为10,不为空
3.数值策略,有四种:Auto,Identity,Sequence,Table
identity:数据的自增长方式,就是从1,2,3,4,5,6如此递增
sequence:序列化,不支持ID自增长的,用于oracle数据库的
table:表方式生成组件的
auto:若不特定指的话,就是给系统自己生成策略,让它在上述三个选项之中进行选择

设置日期 -- 时间戳

@Temporal(temporaltype.DATE)
public Date getDate(){}

枚举设置

如果设置了枚举为length - 分为长(long)和短(short)

@Enumerated(TYPE.String)

表示设置枚举类型为字符型

如果存储量大

@Lob ->针对大文本类型的
@Basice(fetch = fetchtype.late or early) ->设置加载方式,是快速加载还是懒加载
//然后说点题外话,get/set方法生成:鼠标右击,soure->Generate getter and setters
//定义一个集合兼泛型的内容 -- 就是定义了一个只存储person类模型的一个集合 
private Set<Person> persons;

多对一或者一对多设置

@onetomany : 一对多
延伸:mappedBy="xxxxxx"
这里,哪个位置出现了,哪个就是关系的被维护端,然后里面的内容填写的,是被维护的关系
@onetoone : 一对一
(optional:false):表示不是可选值,也就是非空的意思

@cascade=(cascadeType.xxxx)操作

.prsist:级联持久化操作(持久保存拥有方实体,也会保存该实体的相关数据)
.remove:级联删除操作(删除一个实体时,也会删除该实体的所有相关数据)
.merge级联更新(合并)操作(将分离的实体诚信合并到活动的持久性上下文时,也会合并该实体内所有相关数据)
.refresh 级联刷新操作(只会查询获取操作)
.all 包含以上全部操作

@JoinColumn(name="idcard_id")在某个属性上写的方法,意思为设置外键,字段名为idcard_id

对于@column与@joinColumn,在不设置name情况下,默认的规则:

name = 关联表的名称 + "_" + 关联表主键的名称

比方:

@joinColumn(name="address_id" referencedColumnName="ref_id")

这个说明ref_id不是关联表的主键
这句话的含义是:表中"address_id"字段关联的是"ref_id"属性referencedColumnName标准的是所关联表中的字段名,若不指定则使用的关联表的主键字段名作为外键
@joinTable : 关联表

上一篇下一篇

猜你喜欢

热点阅读