JPA常用註解彙總紀要
註解Column詳解
Column的主要屬性資訊:
- name 自定義資料庫的欄位名稱
- nullable 是否為空
- length: 如果是字元型,可以限定長度
- unqiue 是否為唯一性
- precision/scale 對於小數的精度控制
- insertable/updatable 可插入/可更新設定
@Column用來建立模型物件與資料庫表欄位之間的對映關係,可以使用在方法和屬性上。
在不做宣告的情況下,預設會建立與資料庫的對映。
詳細的資訊可以參閱其原始碼的說明:
/**
* Specifies the mapped column for a persistent property or field.
* If no <code>Column</code> annotation is specified, the default values apply.
*
* <blockquote><pre>
* Example 1:
*
* @Column(name="DESC", nullable=false, length=512)
* public String getDescription() { return description; }
*
* Example 2:
*
* @Column(name="DESC",
* columnDefinition="CLOB NOT NULL",
* table="EMP_DETAIL")
* @Lob
* public String getDescription() { return description; }
*
* Example 3:
*
* @Column(name="ORDER_COST", updatable=false, precision=12, scale=2)
* public BigDecimal getCost() { return cost; }
*
* </pre></blockquote>
*
*
* @since Java Persistence 1.0
*/
@Target({METHOD, FIELD})
@Retention(RUNTIME)
public @interface Column {
/**
* (Optional) The name of the column. Defaults to
* the property or field name.
*/
String name() default "";
/**
* (Optional) Whether the column is a unique key. This is a
* shortcut for the <code>UniqueConstraint</code> annotation at the table
* level and is useful for when the unique key constraint
* corresponds to only a single column. This constraint applies
* in addition to any constraint entailed by primary key mapping and
* to constraints specified at the table level.
*/
boolean unique() default false;
/**
* (Optional) Whether the database column is nullable.
*/
boolean nullable() default true;
/**
* (Optional) Whether the column is included in SQL INSERT
* statements generated by the persistence provider.
*/
boolean insertable() default true;
/**
* (Optional) Whether the column is included in SQL UPDATE
* statements generated by the persistence provider.
*/
boolean updatable() default true;
/**
* (Optional) The SQL fragment that is used when
* generating the DDL for the column.
* <p> Defaults to the generated SQL to create a
* column of the inferred type.
*/
String columnDefinition() default "";
/**
* (Optional) The name of the table that contains the column.
* If absent the column is assumed to be in the primary table.
*/
String table() default "";
/**
* (Optional) The column length. (Applies only if a
* string-valued column is used.)
*/
int length() default 255;
/**
* (Optional) The precision for a decimal (exact numeric)
* column. (Applies only if a decimal column is used.)
* Value must be set by developer if used when generating
* the DDL for the column.
*/
int precision() default 0;
/**
* (Optional) The scale for a decimal (exact numeric) column.
* (Applies only if a decimal column is used.)
*/
int scale() default 0;
}
日期型別定義
Date: @Temperal(TemperalType.TIMESTAMP/DATE/TIME)
示例如下:
@Column(name = "created_time")
@Temporal(TemporalType.TIMESTAMP)
private Date createdTime;
列舉型別
定義列舉類, 其有兩個值:Male/Female
public enum Gender {
Female, Male
}
領域物件的列定義:
@Column(name="t_gender", nullable=false)
@Enumerated(EnumType.ORDINAL)
private Gender gender;
上述列定義中EnumType支援String/Ordinal型別, String是列舉的字元描述值,Ordinal是其位置資訊,例如Female其位置為0, Male的位置為1,其存入資料庫的值即為0/1.
如果需要自定義列舉的值,例如Female之時,存入10, Male之時,存入20.該如何來處理呢?
首先重新定義列舉類:
@Getter
public enum Gender {
Male("Male", 20), Female("Female", 10);
private String name;
private Integer index;
private Gender(String name, Integer index) {
this.name = name;
this.index = index;
}
public static Gender fromInteger(Integer indexNum) {
Objects.requireNonNull(indexNum);
if (indexNum.intValue() == Female.index.intValue()) {
return Female;
}
else
return Male;
}
}
在列舉類中,定義了構造方法和一個靜態方法,基於index值獲取對應的列舉物件。
自定義Gender類的Coverter轉換器:
@Converter
public class GenderConverter implements AttributeConverter<Gender, Integer> {
@Override
public Integer convertToDatabaseColumn(Gender attribute) {
return attribute.getIndex();
}
@Override
public Gender convertToEntityAttribute(Integer dbData) {
return Gender.fromInteger(dbData);
}
}
注意這裡的範型使用<Gender, Integer>,第一個是列舉類,第二個是Index型別。
這個Converter將用來轉化Gender的列舉型別。
宣告使用Converter來自動轉化Gender的Domain物件值,示例如下:
@Column(nullable=false, name="gender")
@Convert(converter = GenderConverter.class)
private Gender gender = Gender.Male;
這裡Gender型別的屬性設定了預設值Male,通過@Convert註解來宣告使用GenderConverter轉化類。
儲存空間大的資料型別
@Lob: 用來宣告欄位需要大的儲存空間。
如果宣告瞭String型別, 則在資料庫中預設對映為LongText。
對於二進位制資料,domain物件使用byte/Byte[], 則資料庫中型別對映為LongBlob。
由於此欄位比較大,如果直接載入,則會消耗很大記憶體。如果設定為延遲載入,則會更為人性化,可以通過@Basic(fetch=LAZY/EAGER)設定為延遲載入:
使用示例如下:
@Lob
@Basic(fetch=LAZY)
private Byte[] file;
排除持久化欄位宣告
@Transient 欄位名稱
預設使用欄位對映, 通過@Transient設定,不用資料庫欄位的對映。
相關文章
- MapStruct - 註解彙總Struct
- SpringBoot2.x系列教程之 SpringBoot常用註解彙總Spring Boot
- 解壓命令unzip常用方法彙總
- Spring/SpringBoot常用註解總結Spring Boot
- 絕對要收藏!!! JavaEE開發常用註解Java
- 使用Spring Data Jpa遇到問題彙總Spring
- Oracle 常用方法彙總Oracle
- 常用函式彙總函式
- Git 常用操作彙總Git
- 《區塊鏈常用術語解釋》彙總區塊鏈
- 阿里雲常用產品彙總及解釋阿里
- 如何使用JPA的@Formula註解?ORM
- 常用註解
- My SQL常用操作彙總SQL
- 【Linq】常用語法彙總
- Excel常用快捷鍵彙總Excel
- 常用壓縮命令彙總
- MySQL常用函式彙總MySql函式
- AA常用函式彙總函式
- MySql 常用語法彙總MySql
- 常用工具彙總
- PHP 常用函式彙總PHP函式
- @Query註解的用法(Spring Data JPA)Spring
- es6常用方法彙總
- Android Studio常用快捷鍵彙總Android
- npm常用命令彙總NPM
- MogDB openGauss常用查詢彙總
- 常用免費好用API彙總API
- linux 常用命令彙總Linux
- Pytorch常用程式碼段彙總PyTorch
- ffmpeg常用命令彙總
- Mysql常用命令彙總MySql
- 陣列常用函式彙總陣列函式
- MySQL 常用命令彙總MySql
- Springboot 常用註解Spring Boot
- Lombok常用註解Lombok
- Spring常用註解Spring
- Mysql 常用函式(1)- 常用函式彙總MySql函式