美文网首页
后端的jpa学习

后端的jpa学习

作者: 一米押金 | 来源:发表于2017-04-01 16:04 被阅读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 : 关联表

    相关文章

      网友评论

          本文标题:后端的jpa学习

          本文链接:https://www.haomeiwen.com/subject/klbiottx.html