Hibernate @Column、columnDefinition等简介(注意日期类型)

2024-08-22 02:32

本文主要是介绍Hibernate @Column、columnDefinition等简介(注意日期类型),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

主要包括:

  1. @Id、@GeneratedValue
  2. @Column
  3. @Column之columnDefinition
  4. @Column控制浮点数精度
  5. @Temporal
  6. @Transient

 

 

@Id: 
@Id 标注用于声明一个实体类的属性映射为数据库的主键列。该属性通常置于属性声明语句之前,可与声明语句同行,也可写在单独行上。
@Id标注也可置于属性的getter方法之前。

@GeneratedValue: 
@GeneratedValue 用于标注主键的生成策略,通过strategy 属性指定。默认情况下,JPA 自动选择一个最适合底层数据库的主键生成策略:SqlServer对应identity,MySQL 对应 auto increment。 
在javax.persistence.GenerationType中定义了以下几种可供选择的策略: 
–IDENTITY:采用数据库ID自增长的方式来自增主键字段,Oracle 不支持这种方式;
–AUTO: JPA自动选择合适的策略,是默认选项; 
–SEQUENCE:通过序列产生主键,通过@SequenceGenerator 注解指定序列名,MySql不支持这种方式 
–TABLE:通过表产生主键,框架借由表模拟序列产生主键,使用该策略可以使应用更易于数据库移植。

推荐的两种写法: 
属性之上:

 

@Table(name="CUSTOMERS")
@Entity
public class Customer {@GeneratedValue(strategy=GenerationType.AUTO)@Idprivate Integer id;private String name;private String email;private int age;public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}

 

 

getter方法之上

 

@Table(name="CUSTOMERS")
@Entity
public class Customer {private Integer id;private String name;private String email;private int age;@GeneratedValue(strategy=GenerationType.AUTO)@Idpublic Integer getId() {return id;}public void setId(Integer id) {this.id = id;}

 但是不能某个注解在属性之上,某个注解在getter之上,将抛出异常,对其他注解也相同

 

 

@Table(name="CUSTOMERS")
@Entity
public class Customer {@Idprivate Integer id;private String name;private String email;private int age;@GeneratedValue(strategy=GenerationType.AUTO)public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}

 上面的写法是错误的

 

@Column: 
当实体的属性与其映射的数据库表的列不同名时需要使用@Column 标注说明,该属性通常置于实体的属性声明语句之前,还可与 @Id 标注一起使用。
@Column 标注的常用属性是name,用于设置映射数据库表的列名。此外,该标注还包含其它多个属性,如:unique、nullable、length 等。 
@Column 标注的columnDefinition属性: 表示该字段在数据库中的实际类型.通常 ORM 框架可以根据属性类型自动判断数据库中字段的类型,但是对于Date类型仍无法确定数据库中字段类型究竟是DATE,TIME还是TIMESTAMP.此外,String的默认映射类型为VARCHAR,如果要将 String 类型映射到特定数据库的 BLOB 或TEXT字段类型.
@Column标注也可置于属性的getter方法之前

name属性: 
name属性定义了被标注字段在数据库表中所对应字段的名称

unique属性: 
unique属性表示该字段是否为唯一标识,默认为false。 
如果表中有一个字段需要唯一标识,则既可以使用该标记,也可以使用@Table注解中的@UniqueConstraint,详情可参考@Table注解 详解

nullable属性: 
nullable属性表示该字段是否可以为null值,默认为true

insertable属性: 
insertable属性表示在使用”INSERT”语句插入数据时,是否需要插入该字段的值

updateable属性: 
updateable属性表示在使用”UPDATE”语句插入数据时,是否需要更新该字段的值

insertable和updateable属性一般多用于只读的属性,例如主键和外键等,这些字段通常是自动生成的

columnDefinition属性: 
columnDefinition属性表示创建表时,该字段创建的SQL语句,一般用于通过Entity生成表定义时使用 
如果数据库中表已经建好,该属性没有必要使用

table属性: 
table属性定义了包含当前字段的表名

length属性: 
length属性表示字段的长度,当字段的类型为varchar时,该属性才有效,默认为255个字符

precision属性和scale属性: 
precision属性和scale属性一起表示精度,当字段类型为double时,precision表示数值的总长度,scale表示小数点所占的位数

columnDefinition属性的使用:

@Table(name = "CUSTOMERS")
@Entity
public class Customer {@Column(name = "ID")@GeneratedValue(strategy = GenerationType.AUTO)@Idprivate Integer id;@Column(name = "Name")private String name;@Column(name = "Email",columnDefinition="varchar(128) not null")private String email;@Column(name = "Age")private int age;......
}
  数据库DDL:

 

 

CREATE TABLE `customers` (`ID` int(11) NOT NULL AUTO_INCREMENT,`Age` int(11) DEFAULT NULL,`Email` varchar(128) NOT NULL,`Name` varchar(255) DEFAULT NULL,PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
 columnDefinition可以指定创建表时一些SQL语句,比如这里可以一次性指定,varchar长度128,且不能为空 

 

当然,相同的结果可以通过nullable和length属性结合实现

 

@Table(name = "CUSTOMERS")
@Entity
public class Customer {@Column(name = "ID")@GeneratedValue(strategy = GenerationType.AUTO)@Idprivate Integer id;@Column(name = "Name")private String name;@Column(name = "Email", nullable = true, length = 128)private String email;@Column(name = "Age")private int age;......
}

 数据库DDL:

 

 

CREATE TABLE `customers` (`ID` int(11) NOT NULL AUTO_INCREMENT,`Age` int(11) DEFAULT NULL,`Email` varchar(128) DEFAULT NULL,`Name` varchar(255) DEFAULT NULL,PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

 

CREATE TABLE `customers` (`ID` int(11) NOT NULL AUTO_INCREMENT,`Age` int(11) DEFAULT NULL,`Email` varchar(128) DEFAULT NULL,`Name` varchar(255) DEFAULT NULL,`Remark` text,`Salary1` decimal(5,2) DEFAULT NULL,`Salary2` double DEFAULT NULL,`Salary3` decimal(5,2) DEFAULT NULL,`Salary4` decimal(5,2) DEFAULT NULL,PRIMARY KEY (`ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

 columnDefinition属性的特殊使用: 

 

编程语言中字符串一般都用String表示,但是数据库中varcahr数值类型有长度限制,一旦需要大文本,则需要text数值类型
但是String类型默认映射的数值类型是varchar,columnDefinition可以进行额外指定

@Table(name = "CUSTOMERS")
@Entity
public class Customer {@Column(name = "ID")@GeneratedValue(strategy = GenerationType.AUTO)@Idprivate Integer id;@Column(name = "Name")private String name;@Column(name = "Email", nullable = true, length = 128)private String email;@Column(name = "Age")private int age;@Column(name = "Remark",columnDefinition="text")private String remark;}

 数据库DDL:

 

 

CREATE TABLE `customers` (`ID` int(11) NOT NULL AUTO_INCREMENT,`Age` int(11) DEFAULT NULL,`Email` varchar(128) DEFAULT NULL,`Name` varchar(255) DEFAULT NULL,`Remark` text,PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

 remark列数值类型是text,而Name和Email默认是varcahr

 

控制浮点精度:

 

@Table(name = "CUSTOMERS")
@Entity
public class Customer {@Column(name = "ID")@GeneratedValue(strategy = GenerationType.AUTO)@Idprivate Integer id;@Column(name = "Name")private String name;@Column(name = "Email", nullable = true, length = 128)private String email;@Column(name = "Age")private int age;@Column(name = "Remark", columnDefinition = "text")private String remark;@Column(name = "Salary1", columnDefinition = "decimal(5,2)")private double salary1;@Column(name = "Salary2", precision = 5, scale = 2)private double salary2;@Column(name = "Salary3", columnDefinition = "decimal(5,2)")private BigDecimal salary3;@Column(name = "Salary4", precision = 5, scale = 2)private BigDecimal salary4;}
  数据库DDL:
CREATE TABLE `customers` (`ID` int(11) NOT NULL AUTO_INCREMENT,`Age` int(11) DEFAULT NULL,`Email` varchar(128) DEFAULT NULL,`Name` varchar(255) DEFAULT NULL,`Remark` text,`Salary1` decimal(5,2) DEFAULT NULL,`Salary2` double DEFAULT NULL,`Salary3` decimal(5,2) DEFAULT NULL,`Salary4` decimal(5,2) DEFAULT NULL,PRIMARY KEY (`ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  总结:  

1.double类型将在数据库中映射为double类型,precision和scale属性无效 
2.double类型若在columnDefinition属性中指定数字类型为decimal并指定精度,则最终以columnDefinition为准 
3.BigDecimal类型在数据库中映射为decimal类型,precision和scale属性有效 
4.precision和scale属性只在BigDecimal类型中有效

在核心的JPA API中没有定义Date类型的精度,数据库中表示Date类型的数据有DATE,TIME,TIMESTAMP三种精度,可通过@Temporal注解进行调整

 

@Table(name = "CUSTOMERS")
@Entity
public class Customer {@Column(name = "ID")@GeneratedValue(strategy = GenerationType.AUTO)@Idprivate Integer id;@Column(name = "Name")private String name;@Column(name = "Email")private String email;@Column(name = "Age")private int age;@Temporal(TemporalType.DATE)@Column(name="Birthday")private Date birthday;@Temporal(TemporalType.TIMESTAMP)@Column(name="CreateTime")private Date createTime;}

 数据库DDL:

CREATE TABLE `customers` (`ID` int(11) NOT NULL AUTO_INCREMENT,`Age` int(11) DEFAULT NULL,`Birthday` date DEFAULT NULL,`CreateTime` datetime DEFAULT NULL,`Email` varchar(255) DEFAULT NULL,`Name` varchar(255) DEFAULT NULL,PRIMARY KEY (`ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

 当然@Column的columnDefinition属性也可以实现相同的效果

@Table(name = "CUSTOMERS")
@Entity
public class Customer {@Column(name = "ID")@GeneratedValue(strategy = GenerationType.AUTO)@Idprivate Integer id;@Column(name = "Name")private String name;@Column(name = "Email")private String email;@Column(name = "Age")private int age;@Column(name="Birthday",columnDefinition="date")private Date birthday;@Column(name="CreateTime",columnDefinition="datetime")private Date createTime;}

 @Transient: 

表示该属性并非一个到数据库表的字段的映射,ORM框架将忽略该属性.
如果一个属性并非数据库表的字段映射,就务必将其标示为@Transient,否则,ORM框架默认其注解为@Basic

当实体对象中有一些独有属性时,可以使用该注解,进行忽略

@Table(name = "CUSTOMERS")
@Entity
public class Customer {@Column(name = "ID")@GeneratedValue(strategy = GenerationType.AUTO)@Idprivate Integer id;@Column(name = "Name")private String name;@Column(name = "Email")private String email;@Column(name = "Age")private int age;@Transientprivate String address;}

 数据库DDL:

CREATE TABLE `customers` (`ID` int(11) NOT NULL AUTO_INCREMENT,`Age` int(11) DEFAULT NULL,`Email` varchar(255) DEFAULT NULL,`Name` varchar(255) DEFAULT NULL,PRIMARY KEY (`ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

 数据库表中不会创建address列

 

转载地址:http://blog.csdn.net/Rickesy/article/category/6116937

这篇关于Hibernate @Column、columnDefinition等简介(注意日期类型)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1094980

相关文章

Golang的CSP模型简介(最新推荐)

《Golang的CSP模型简介(最新推荐)》Golang采用了CSP(CommunicatingSequentialProcesses,通信顺序进程)并发模型,通过goroutine和channe... 目录前言一、介绍1. 什么是 CSP 模型2. Goroutine3. Channel4. Channe

IDEA如何将String类型转json格式

《IDEA如何将String类型转json格式》在Java中,字符串字面量中的转义字符会被自动转换,但通过网络获取的字符串可能不会自动转换,为了解决IDEA无法识别JSON字符串的问题,可以在本地对字... 目录问题描述问题原因解决方案总结问题描述最近做项目需要使用Ai生成json,可生成String类型

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

Mysql 中的多表连接和连接类型详解

《Mysql中的多表连接和连接类型详解》这篇文章详细介绍了MySQL中的多表连接及其各种类型,包括内连接、左连接、右连接、全外连接、自连接和交叉连接,通过这些连接方式,可以将分散在不同表中的相关数据... 目录什么是多表连接?1. 内连接(INNER JOIN)2. 左连接(LEFT JOIN 或 LEFT

Redis的Hash类型及相关命令小结

《Redis的Hash类型及相关命令小结》edisHash是一种数据结构,用于存储字段和值的映射关系,本文就来介绍一下Redis的Hash类型及相关命令小结,具有一定的参考价值,感兴趣的可以了解一下... 目录HSETHGETHEXISTSHDELHKEYSHVALSHGETALLHMGETHLENHSET

Python中异常类型ValueError使用方法与场景

《Python中异常类型ValueError使用方法与场景》:本文主要介绍Python中的ValueError异常类型,它在处理不合适的值时抛出,并提供如何有效使用ValueError的建议,文中... 目录前言什么是 ValueError?什么时候会用到 ValueError?场景 1: 转换数据类型场景

C# dynamic类型使用详解

《C#dynamic类型使用详解》C#中的dynamic类型允许在运行时确定对象的类型和成员,跳过编译时类型检查,适用于处理未知类型的对象或与动态语言互操作,dynamic支持动态成员解析、添加和删... 目录简介dynamic 的定义dynamic 的使用动态类型赋值访问成员动态方法调用dynamic 的

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依