JPA設置默認字段及其長度詳解
使用jpa去生成對應的值的長度和默認值是如何設置的呢
@Target({ElementType.METHOD, ElementType.FIELD}) @Retention(RetentionPolicy.RUNTIME) public @interface Column { String name() default ""; boolean unique() default false; boolean nullable() default true; boolean insertable() default true; boolean updatable() default true; String columnDefinition() default ""; String table() default ""; int length() default 255; int precision() default 0; int scale() default 0; }
- name 屬性用來設置字段的名字
- unique用於設置這個字段是否是是唯一的
- insertable和updatable、table都是和表更新相關的操作,
- length 指定長度,默認是255
- precision 數據長度
- scale小數的長度
- columnDefinition 指定這一列的信息
String
string是最常見的字段,
@Column(name = “name”) private String name;
SQL中 name varchar(255)
生成的字段長度為255,即如果不設置長度的話默認的長度就是255個。
@Column(name = “name”,length = 50) private String name;
name varchar(50)
@Column(name = “name”,columnDefinition=“varchar(11) COMMENT ‘用戶姓名'”) private String name;
name varchar(11) COMMENT ‘用戶姓名'
這裡不僅指定瞭長度,還給列瞭一個註釋,便於查看
@Column(name = “name”,columnDefinition=“default ‘12345'”) private String name;
如果我們制定默認值,這樣SQL語句就會報錯
create table user (id bigint not null, age integer, birth datetime(6), name default ‘12345', sex bit, primary key (id)) engine=InnoDB
如果我們制定長度呢
@Column(name = “name”,columnDefinition=“default ‘12345'”,length = 25) private String name;
運行的DDL語句依然無法創建出表
create table user (id bigint not null, age integer, birth datetime(6), name default ‘12345', sex bit, primary key (id)) engine=InnoDB
如何給String字段指定默認值呢
所以如果指定columnDefinition這個屬性會覆蓋原來的列註解的長度,而且在其註解的中必須制定列的類型
/** * (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 "";
/** *(可選)在以下情況下使用的SQL片段: *正在為列生成DDL。 *默認使用生成的SQL來創建推斷類型的列。 */
@Column(name = “name”,columnDefinition=" varchar(11) default ‘12345'",length = 25) private String name; create table user (id bigint not null, age integer, birth datetime(6), name varchar(11) default ‘12345', sex bit, primary key (id)) engine=InnoDB
columnDefinition 會將其中的值作為列名之後,如果在這裡設置默認值,必須保證直接加在列名之後執行不會出錯。
定義 Integer 和 Long 有區別嗎
Long的默認長度為20,Integer的默認長度為11
定義Integer和int有區別嗎
區別是int如果你不給他設置就會默認為0
boolean和Boolean也是一樣的。
boolean類型
默認長度為1
@Column(name = “sex”) private Boolean sex;
@Column(name = “sex”) private boolean sex;
二者沒有什麼區別,如果我們將boolean設置默認值並且設置長度會咋樣呢?
@Column(name = “sex”,length = 50) private boolean sex;
生成的DDL語句中並沒有長度的屬性。所以在boolean類型中設置長度屬性是沒有作用的
create table user (id bigint not null, age integer, birth datetime(6), name varchar(255), sex bit, primary key (id)) engine=InnoDB
指定boolean類型的默認值呢
@Column(name = “sex”,columnDefinition = “bit(1) default 1”) private boolean sex;
有註意,如果指定默認值為1,即是true,屬性如果不指定,boolean的默認值就是false,所以會將false設置到對應的數據中,如果指定Boolean呢
如果指定Boolean的話,沒有設置默認就是null,就會將空更新到數據庫中,最好用的方法還是在java類中設置默認值。
日期
默認的日期格式不具有可讀性
@Column(name = "birth") private Date birth;
使用@Temporal來制定格式
@Temporal(TemporalType.DATE) @Column(name = "birth") private Date birth;
@Temporal有三個值
- DATE 隻有日期
- TIME 隻有時間 時分秒
- TIMESTAMP 日期和時間都有
浮點數格式的設置
@Column(name = “age”,scale = 2) private int age;
age integer,屬性為scale = 2沒有作用
@Column(name = “age”,scale = 2) private float age;
@Column(name = “age”,precision = 5,scale = 2) private float age;
還是沒有用,指定數據格式為double,依然沒有用
@Column(name = “age”,columnDefinition = “decimal(5,2)”) private double age;
大文本
/** * 備註 */ @Basic(fetch = FetchType.LAZY) @Type(type = "text") @Lob @Column(name = "remark") private String remark;
@Lob 指定該文本為長文本
@Basic(fetch = FetchType.LAZY) 長文本緩加載,便於數據的讀取。
以上就是JPA設置默認字段及其長度詳解的詳細內容,更多關於JPA設置默認字段及長度的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- MySQL中的隱藏列的具體查看
- jpa 使用@Column來定義字段類型
- Spring Data JPA 設置字段默認值方式
- JavaWeb倉庫管理系統詳解
- MySQL中你可能忽略的COLLATION實例詳解