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其它相關文章!

推薦閱讀: