基本注解

  1、@Entity :用于添加在实体类上,定义该JAVA类成为被JPA管理的实体,将映射到指定的数据库表。如定义一个实体类Category,它将映射到数据库中的category表中。

  2、@Id :定义属性为数据库表中的主键列,一个实体里面必须有一个。

  3、@Table:指定数据库的表名,与@Entity一同使用。

      属性name:表的名字,如果不写,系统认为和实体类一致。

      属性catalog,schema用于设置目录和此表所在schema,一般不需要填写;

      属性uniqueConstraints,唯一性约束,只有创建表的时候有用,默认不需要;

      属性indexes,索引,只有创建表的时候有用,默认不需要。

  4、@Basic:表示属性是到数据库表字段的映射。如果实体的字段上没有任何注解,默认即为@Basic;

      属性fetch,抓取方式,默认FetchType.EAGER(立即加载),FetchType.LAZY(延迟加载,主要应用在大字段上面);

      属性optional,设置这个字段是否可以为null,默认是true。

  5、@Transient:非持久化属性,表示该属性并非是一个到数据库表的字段的映射,与@Basic作用相反。JPA映射数据库的时候忽略它。

  6、@Column:定义该属性对应数据库中的列名。

      属性name,数据库中的列名。如果不写默认和实体属性名一致;

      属性unique,是否唯一。默认false;

      属性nullable,是否允许为空。默认为true;

      属性insertable,执行insert操作的时候是否包含此字段,默认为true;

      属性updatable,执行updatable操作的时候是否包含此字段,默认为true;

      属性columnDefinition,表示该字段在数据库中的实际类型。

      属性length,数据库字段的长度,默认255;

      属性table,precision,scale,我没用到过,一般不设置。

  7、@GeneratedValue:主键生成策略。

      属性strategy,id的生成策略,GenerationType.TABLE,通过表产生主键,框架由表模拟序列产生主键,使用该策略可以使应用更易于数据库移植;GenerationType.SEQUENCE,通过序列产生主键,通过@SequenceGenerator注解指定序列名,MySql不支持这种方式;GenerationType.IDENTITY,数据库id自增长,多用于MySql;GenerationType.AUTO,JPA自动选择合适的策略,默认选项。

      属性generator:通过Sequence生成id,常见Orcale数据库id生成,需要配合@SequenceGenerator使用。

  8、@Temporal:用来设置Date类型的属性映射到对应精度的字段。TemporalType.DATE,映射为数据库date,TemporalType.TIME映射为数据库time,TemporalType.TIMESTAMP,映射为datetime。(jdk8的话,可以使用新的时间类来替代Date)

  9、@Enumerated:映射枚举字段。属性value,默认是EnumType.ORDINAL(枚举字段的下标),EnumType.STRING枚举字段的Name;应用如下

        

  10、@Lob,将属性字段映射成数据库支持的大对象类型,支持一下两种数据库类型的字段。

      Clob(Character Large Objects)类型是长字符串类型,java.sql.Clob、Character[]、char[]和String将被映射成Clob类型。

      Blob(Binary Large Objects)类型是字节类型,java.sql.Blob、Byte[]、byte[]和实现了Serializable接口的类型将被映射为Blob类型。

      由于Clob、Blob占用内存空间较大,一般配合@Basic(fetch=FetchType.LAZY)将其设置为延迟加载。

  11、@IdClass:利用外部类的联合主键。

      外部类要符合一下几点:必须实现java.io.Serializable接口;必须有默认的无参构造函数;必须覆盖equals和hashCode方法。    

          

      实体类要,在类上添加@IdClass并指定外部主键类,每个主键上都要添加@Id注解。

          

      Repository接口要把主键改为外部主键类。

          

      使用如下

      

源码地址:https://github.com/caofanqi/study-spring-data-jpa

      

学习Spring-Data-Jpa(二)---JPA基本注解的更多相关文章

  1. 一步步学习 Spring Data 系列之JPA(一)

    引入: Spring Data是SpringSource基金会下的一个用于简化数据库访问,并支持云服务的开源框架.其主要目标是使得数据库的访问变得方便快捷,并支持map-reduce框架和云计算数据服 ...

  2. 一步步学习 Spring Data 系列之JPA(二)

    继上一篇文章对Spring Data JPA更深( )一步剖析. 上一篇只是简单的介绍了Spring Data JPA的简单使用,而往往在项目中这一点功能并不能满足我们的需求.这是当然的,在业务中查询 ...

  3. Spring Data(二)查询

    Spring Data(二)查询 接着上一篇,我们继续讲解Spring Data查询的策略. 查询的生成 查询的构建机制对于Spring Data的基础是非常有用的.构建的机制将截断前缀find-By ...

  4. spring AOP 之二:@AspectJ注解的3种配置

    @AspectJ相关文章 <spring AOP 之二:@AspectJ注解的3种配置> <spring AOP 之三:使用@AspectJ定义切入点> <spring ...

  5. 学习Spring Data JPA

    简介 Spring Data 是spring的一个子项目,在官网上是这样解释的: Spring Data 是为数据访问提供一种熟悉且一致的基于Spring的编程模型,同时仍然保留底层数据存储的特​​殊 ...

  6. Spring Data Jpa (二)JPA基础查询

    介绍Spring Data Common里面的公用基本方法 (1)Spring Data Common的Repository Repository位于Spring Data Common的lib里面, ...

  7. 学习-spring data jpa

    spring data jpa对照表 Keyword Sample JPQL snippet And findByLastnameAndFirstname - where x.lastname = ? ...

  8. Spring Data系列之Jpa(一)

    1.Spring Data的由来 Spring Data是SpringSource基金会创下的一个简化数据库访问.支持云服务的开源框架.其主要目的是让数据库访问变的方便快捷,可以用Spring Dat ...

  9. 深入学习Spring框架(二)- 注解配置

    1.为什么要学习Spring的注解配置? 基于注解配置的方式也已经逐渐代替xml.所以我们必须要掌握使用注解的方式配置Spring. 关于实际的开发中到底使用xml还是注解,每家公司有着不同的使用习惯 ...

  10. Spring入门(二)— IOC注解、Spring测试、AOP入门

    一.Spring整合Servlet背后的细节 1. 为什么要在web.xml中配置listener <listener> <listener-class>org.springf ...

随机推荐

  1. 《Docker Deep Dive》Note - Docker 引擎

    <Docker Deep Dive>Note Docker 引擎 1. 概览 graph TB A(Docker client) --- B(daemon) subgraph Docker ...

  2. SAS学习笔记63 如何导出Log

    如上,将Log输出,然后又恢复到SAS系统里面的Log,把需要运行的程序放到他们中间就可以了.这种方法不会出现Log打印满了的情况 这种是先输出在SAS系统里面,然后在输出,在SAS里面Log的行是有 ...

  3. PXC安装部署

    安装依赖与注意事项:   1. rpm -ivh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm 1 ...

  4. Centos7部署开源聊天软件rocket.chat

    一.部署rocket.chat 1.看官方文档部署,很简单,一步一步跟着部署即可 注意:需要部署节点需要联网主要是yum方式 https://rocket.chat/docs/installation ...

  5. C# vb .net实现透视反射效果

    在.net中,如何简单快捷地实现Photoshop滤镜组中的透视反射效果呢?答案是调用SharpImage!专业图像特效滤镜和合成类库.下面开始演示关键代码,您也可以在文末下载全部源码: 设置授权 第 ...

  6. 转 C# 使用openssl

    //先用大整数来生成一个1024bit的密钥对 RSA rsa = new RSA(); BigNumber number = OpenSSL.Core.Random.Next(10, 10, 1); ...

  7. ubuntu classicmenu-indicator

      sudo add-apt-repository ppa:diesch/testing sudo apt-get update sudo apt-get install classicmenu-in ...

  8. 网页包抓取工具Fiddler工具简单设置

    当下载好fiddler软件后首先通过以下简单设置,或者有时候fiddler抓取不了浏览器资源了.可以通过以下设置. 设置完成后重启软件.打开网络看看有没有抓取到包.

  9. Java调用WebService方法总结(5)--Axis2调用WebService

    Axis2是新一点Axis,基于新的体系结构进行了全新编写,有更强的灵活性并可扩展到新的体系结构.文中demo所使用到的软件版本:Java 1.8.0_191.Axis2 1.7.9. 1.准备 参考 ...

  10. 易百教程人工智能python修正-人工智能数据准备-预处理数据

    预处理数据 在我们的日常生活中,需要处理大量数据,但这些数据是原始数据. 为了提供数据作为机器学习算法的输入,需要将其转换为有意义的数据. 这就是数据预处理进入图像的地方. 换言之,可以说在将数据提供 ...