2、JPA-Annotation
注解放在类属性上不生效时可放在get方法上试试,原因未知
@Entity
/**
* @Entity 该Java类为实体类,将映射到数据库表。如声明一个实体类 Customer,它将映射到数据库中的 customer 表上。
*/
@Entity
public class Customer {
@Table
@Table(name = "JPA_CUTOMERS")
/**
* @Table 当实体类与其映射的数据库表名不同名时使用
* name,用于指明数据库的表名
* catalog 和 schema 用于设置表所属的数据库目录或模式,通常为数据库名
* uniqueConstraints 选项用于设置约束条件,通常不须设置
*/
@Entity
public class Customer { private Integer id;
@Id
/**
* @Id 声明一个实体类的属性映射为数据库的主键列。标注可写在属性的getter方法上。
*/
@Id
public Integer getId() {
return id;
}
@GeneratedValue
/**
* @GeneratedValue 用于标注主键的生成策略,通过 strategy 属性指定
* 默认 JPA 自动选择一个最适合底层数据库的主键生成策略:SqlServer 对应 identity,MySQL 对应 auto increment
* 在 javax.persistence.GenerationType 中定义了以下几种可供选择的策略:
* IDENTITY:采用数据库 ID自增长的方式来自增主键字段,Oracle 不支持这种方式
* AUTO: JPA自动选择合适的策略,默认选项
* SEQUENCE:通过序列产生主键,通过 @SequenceGenerator 注解指定序列名,MySql 不支持这种方式
* TABLE:通过表产生主键,框架借由表模拟序列产生主键,使用该策略可以使应用更易于数据库移植
*/
@GeneratedValue(strategy = GenerationType.AUTO)
@Id
public Integer getId() {
return id;
}
@Basic
/**
* @Basic 表示属性到数据库表字段的映射, 对于没有任何注解的 getXxxx() 方法,默认为写了 @Basic
* fetch: 表示该属性的读取策略,有 EAGER 和 LAZY 两种,分别表示主支抓取和延迟加载,默认为 EAGER.
* optional:表示该属性是否允许为null, 默认为true
*/
@Basic(optional = false)
public String getEmail() {
return email;
}
@Column
/**
* @Column 当实体类属性与其映射的数据库表的列不同名时使用
* name,用于设置映射数据库表的列名。此外,该标注还包含其它多个属性,如:unique 、nullable、length 等
* columnDefinition 属性: 表示该字段在数据库中的实际类型
* 通常 ORM 框架可以根据属性类型自动判断数据库中字段的类型,但是对于Date类型仍无法确定数据库中字段类型究竟是 DATE,TIME 还是 TIMESTAMP
* 此外 String 的默认映射类型为 VARCHAR, 如果要将 String 类型映射到特定数据库的 BLOB 或 TEXT 字段类型
*/
@Column(name = "LAST_NAME", length = 50, nullable = false)
public String getLastName() {
return lastName;
}
@Transient
/**
* @Transient 表示该属性不需要映射到数据库表字段,ORM 框架忽略该属性
* 如果一个属性并非数据库表字段映射,需写上 @Transient,否则 ORM 框架默认其注解为 @Basic
*/
@Transient
public String getInof() {
return "Customer{" +
"id=" + id +
", lastName='" + lastName + '\'' +
", email='" + email + '\'' +
", age=" + age +
'}';
}
@Temporal
/**
* @Temporal 在进行时间类属性映射时调整精度
* 在核心的 Java API 中没有定义 Date 类型的精度(temporal precision)
* 在数据库中,表示 Date 类型的数据有 DATE,TIME 和 TIMESTAMP 三种精度(即单纯的日期,时间,或者两者兼备)
*/
@Temporal(TemporalType.TIMESTAMP)
public Date getCreatedTime() {
return createdTime;
} @Temporal(TemporalType.DATE)
public Date getBirth() {
return birth;
}
@TableGenerator
/**
* @TableGenerator 将当前主键的值保存到一个数据库表中,主键的值每次都从指定的表中查询获得
* 这种主键策略可以适用于任何数据库,不必担心不同数据库不兼容造成的问题
* name 该主键生成策略的名称,它与 @GeneratedValue 中设置的 generator 值对应
* table 表生成策略所持久化的表名
* pkColumnName 在持久化表中,该主键生成策略所对应键值的名称
* valueColumnName 在持久化表中,该主键当前所生成的值,它的值将会随着每次创建累加
* pkColumnValue 在持久化表中,该生成策略所对应的主键
* allocationSize 每次主键值增加的大小, 默认值为 50
*/
@TableGenerator(name = "xxx",
table = "jpa_id",
pkColumnName = "pk_name",
pkColumnValue = "CUTOMERS_ID",
valueColumnName = "pk_value",
allocationSize = 2
)
@GeneratedValue(strategy = GenerationType.TABLE, generator = "xxx")
@Id
public Integer getId() {
return id;
}
插入数据表
ID持久化表
2、JPA-Annotation的更多相关文章
- Hibernate or JPA Annotation中BLOB、CLOB注解写法
BLOB和CLOB都是大字段类型,BLOB是按二进制字节码来存储的,而CLOB是可以直接存储字符串的. 在hibernate or JPA Annotation中,实体BLOB.CLOB类型的注解与普 ...
- 4、JPA table主键生成策略(在JPA中table策略是首推!!!)
用 table 来生成主键详解 它是在不影响性能情况下,通用性最强的 JPA 主键生成器.这种方法生成主键的策略可以适用于任何数据库,不必担心不同数据库不兼容造成的问题. initialValue不起 ...
- 3、JPA一些常用的注解
常用注解有下面这些: ①:@Entity.@Table.@Id.@GeneratedValue.@Column.@Basic ②:@Transient 用于忽略某个属性,而不对该属性进行持久化操作 ③ ...
- 转:spring data jpa、 hibernate、 jpa 三者之间的关系
原文链接:spring data jpa. hibernate. jpa 三者之间的关系 spring data jpa hibernate jpa 三者之间的关系 JPA规范与ORM框架之间的关系是 ...
- JPA Annotation注解
JPA & Hibernate 注解 先说说JPA和Hibernate的关系 JPA(Java Persistence API),是Java EE 5的标准ORM接口,也是ejb3规范的一部分 ...
- spring data jpa、 hibernate、 jpa 三者之间的关系
http://www.cnblogs.com/xiaoheike/p/5150553.html JPA规范与ORM框架之间的关系是怎样的呢? JPA规范本质上就是一种ORM规范,注意不是ORM框架-- ...
- Spring Boot多数据源配置(一)durid、mysql、jpa整合
目前在做一个统计项目.需要多数据源整合,其中包括mysql和mongo.本节先讲mysql.durid.jpa与spring-boot的整合. 引入Durid包 <dependency> ...
- spring data jpa 、hibernate、jpa之间的关系
引用:http://blog.csdn.net/u014421556/article/details/52635000 hibernate作为JPA的实现. JPA规范与ORM框架之间的关系 ...
- SpringData Jpa、Hibernate、Jpa 三者之间的关系
JPA规范与ORM框架之间的关系是怎样的呢? JPA规范本质上就是一种ORM规范,注意不是ORM框架--因为JPA并未提供ORM实现,它只是制订了一些规范,提供了一些编程的API接口,但具体实现则由服 ...
- 【Spring Data 系列学习】了解 Spring Data JPA 、 Jpa 和 Hibernate
在开始学习 Spring Data JPA 之前,首先讨论下 Spring Data Jpa.JPA 和 Hibernate 之前的关系. JPA JPA 是 Java Persistence API ...
随机推荐
- kubernetes 安装手册(成功版)
管理组件采用staticPod或者daemonSet形式跑的,宿主机os能跑docker应该本篇教程能大多适用安装完成仅供学习和实验 本次安裝的版本: Kubernetes v1.10.0 (1.10 ...
- 第十九天 标准目录与time 模块
今日内容 1.目录规范 ***** (1)文件夹的规范写法 bin 可执行文件 conf 配置文件 core 主要业务逻辑 db 数据文件 lib 库 (公共代码 第三方模块) log 日志文件 ...
- 使用Putty执行Rsync命令
背景介绍:公司的文件服务器有多个,一个Master服务器,10个左右的Slave服务器. 当Master服务器中的文件更新之后,Slave服务器中的文件也必须做相对应的同步操作. 公司目前使用的Rsy ...
- [luogu2617][bzoj1901][Zju2112]Dynamic Rankings【树套树+树状数组+主席树】
题目网址 [传送门] 题目大意 请你设计一个数据结构,支持单点修改,区间查询排名k. 感想(以下省略脏话inf个字) 真的强力吹爆洛谷数据,一般的树套树还给我T了一般的点,加强的待修主席树还给我卡了几 ...
- 区分IE8/IE7/IE6及其他浏览器
在 CSS中常用特殊字符识别表: (1)*: IE6+IE7都能识别*,而标准浏览器FF+IE8是不能识别*的; (2)!important: 除IE6不能识别 !important外, FF+I ...
- 洛谷P2468 SDOI 2010 粟粟的书架
题意:给你一个矩形书架,每个点是这本书的页数,每次询问(x1,y1)(x2,y2)这个小矩形里最少需要取几本书使得页数和等于Hi. 题解:小数据二位前缀和预处理+二分答案,大数据一行所以用主席树做,感 ...
- Linux记录
多语言环境镜像使用手册 vi和vim上查找字符串 vim 的安装及配置 Linux下的tar压缩解压缩命令详解 vim配置之——ctags与TagList的配置以及NERDTree && ...
- 生命不息,折腾不止 ~ 旧PC改造之家庭影音
前言引入 之前把在校园陪伴多年的旧电脑由Win装成了Linux,的确不卡了,基本上日常办公也够了(大项目还是吃不消,日常捣鼓倒是够了),然后把真正的工作游戏本也改成了Linux,那么旧电脑又变成闲置机 ...
- jsp (2)
一.内置对象: 二.如何在代码中使用js代码: <script type="text/javascript" src="js的路径名"></s ...
- 【UR #3】链式反应
http://uoj.ac/problem/50 %炮姐 好博客 树形结构 枚举根节点的儿子是哪两个 然后列出方程: 然后有EGF的影子! 倍增? 泰勒展开可以把未知数从函数里拿出来!并且变成1次项, ...