JPA实体类中常用的注解
这两天在看黎活明老师的JPA的讲解视频,现在只了解这么多,记录备用。
import java.util.Date; import javax.persistence.Basic;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.EnumType;
import javax.persistence.Enumerated;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Lob;
import javax.persistence.Table;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;
import javax.transaction.Transactional; @Entity(name = "Student") // @Entity:表明本类是一个JPA实体,name的默认值就是类名。
@Table(name = "tbl_student") // @Table:指定和数据库中映射表的名称(默认配置好了数据源)。
public class Student { private Integer id; // 主键,自增 private String name; // 普通string private Date birthday; // 日期类型数据(只保存年月日) private Gender gender; // 枚举类型数据 private String info; // 大文本 private byte[] file; // 二进制文件流 private String imagePath; // 设置这个字段和数据表字段没有映射关系 /*
* 此处穿插一个问题,什么是属性,什么是字段?
* 字段:往上看,上面定义的这些都叫字段。
* 属性:往下看,get方法get后面跟的字符串叫做属性。
*
* 字段和属性有啥区别?
* 自动生成get/set方法时:属性和字段都可以和数据库表字段映射,此时的属性和字段名是一致的。
* 当属性和字段名不一致时:只有属性才会和数据库表字段产生映射。
*
* 所以:
* 使用注解映射属性和数据库表字段的关系时,最好将注解写在get方法上。
* 若是自动生成的get/set方法,即属性和字段名一致时,注解写在字段上面也是ok的。
*/ @Id // @Id:标识主键
@GeneratedValue(strategy = GenerationType.AUTO) // @GeneratedValue:指定自增策略,此处写的是默认策略,会根据不同数据库使用相应的自增方式。
public Integer getId() {
return id;
} public void setId(Integer id) {
this.id = id;
} // @Column:用来指定和数据库表字段的映射,同时可指定数据库中的字段长度,是否唯一,是否可为空等一系列的配置。
@Column(name = "name", length = 30, unique = true, nullable = false)
public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} // @Temporal:指定是日期类型,并且保存格式为年月日(也可以指定为时间或时间戳)。
@Temporal(TemporalType.DATE)
public Date getBirthday() {
return birthday;
} public void setBirthday(Date birthday) {
this.birthday = birthday;
} // @Enumerated:指定是枚举类型,保存时保存字符串。若不指定EnumType.STRING,只会保存在枚举中的下标(index)。
@Enumerated(EnumType.STRING)
@Column(length = 5)
public Gender getGender() {
return gender;
} public void setGender(Gender gender) {
this.gender = gender;
} // @Lob:大文本。如不指定@Lob,最多只能保存255个字符。指定@Lob之后可以保存非常大的文本。
@Lob
public String getInfo() {
return info;
} public void setInfo(String info) {
this.info = info;
} // @Lob:此处@Lob保存的是字符流。
@Lob
@Basic(fetch = FetchType.LAZY) // 此处设置查取对象时延迟加载字符流,避免占用太多的内存。只有用到该属性时,才会去加载。
public byte[] getFile() {
return file;
} public void setFile(byte[] file) {
this.file = file;
} // @Transactional:用于指定该属性和数据库表没有映射关系。
@Transactional
public String getImagePath() {
return imagePath;
} public void setImagePath(String imagePath) {
this.imagePath = imagePath;
} } /*
* 测试枚举类型的枚举类
*/
enum Gender {
MAN, WOMAN
}
JPA实体类中常用的注解的更多相关文章
- JPA实体类中的注解
@Entity 标注于实体类上,通常和@Table是结合使用的,代表是该类是实体类@Table 标注于实体类上,表示该类映射到数据库中的表,没有指定名称的话就表示与数据库中表名为该类的简单类名的表名相 ...
- springMVC 【@response 返回对象自动变成json并且防止乱码】 & 【配置支持实体类中的@DateTimeFormat注解】
在springmvc的配置文件中加上这一段即可 <bean class="org.springframework.web.servlet.mvc.annotation.Annotati ...
- Hibernate jpa 在实体类中对于时间的注解
在时间类型DATE 属性上添加一个 @Temporal(TemporalType.DATE)(精确到年月日)@Temporal(TemporalType.TIME)(精确到时分秒)@Temporal( ...
- 解决Entity 实体类中加了@Id 注解后仍然出现org.hibernate.AnnotationException: No identifier specified for entity 错误
启动报错如下图所示: 解决方案: 查看网上的资料,大部分都说在实体类中没有添加加主键的注解@Id,这个是必须的.但是我的实体类中明明已经添加了@Id,为什么还会报这个错误呢? 后来检查了很久,发现是我 ...
- SSM框架中常用的注解
@Controller:在SpringMVC 中,控制器Controller 负责处理由DispatcherServlet 分发的请求,它把用户请求的数据经过业务处理层处理之后封装成一个Model , ...
- Spring中常用的注解,你知道几个呢?
今天给大家分享下Spring中一般常用的注解都有哪些.可能很多人做了很长是了但有些还是不知道一些注解,不过没有关系,你接着往下看. Spring部分 1.声明bean的注解 @Component 组件 ...
- 利用Java反射机制对实体类的常用操作工具类ObjectUtil
代码: ObjectUtil类: import java.lang.reflect.Field; import java.math.BigDecimal; import java.text.Simpl ...
- Junit中常用的注解说明
Java注解((Annotation)的使用方法是@注解名 ,能通过简单的词语来实现一些功能.在junit中常用的注解有@Test.@Ignore.@BeforeClass.@AfterClass.@ ...
- Java 注释类之常用元注解
Java 注释类之常用元注解 自定义Java注释类时,我们使用方式如下: @Retention(RetentionPolicy.RUNTIME)@Target(ElementType.METHOD ...
随机推荐
- 9.5 dubbo事件通知机制
dubbo事件通知机制:http://dubbo.io/books/dubbo-user-book/demos/events-notify.html 一.使用方式 两个服务: DemoService: ...
- solr中重建索引(转)
Stop your application server Change your schema.xml file Start your application server Delete the in ...
- MySQL实用工具汇总
本文收录了mysql相关的实用工具.工具包括:性能测试,状态分析,SQL路由,及运维开发相关的所有工具,并会持续更新. 1.工具套件集 - percona-toolkit - oak-toolkit ...
- 快速准备(复制替换)一套新测试环境,CentOS7 MySQL相关配置
拿到一个新环境,需要找相关配置,我有一个办法,相对能比较快速地复制一套环境出来. 修改机器配置: virsh 相关几条命令,已完成,后续我再整理补充... 虚拟化相关,参考:https://www.c ...
- 抓取epsg.io的内容
简述 epsg.io是一个查询EPSG坐标系相关信息的好网站,内容很全.有各种格式的定义可以直接下载,也有坐标系的范围名称等相关信息,所以想抓取这些信息下来,方便对接各个系统. epsg.io本身是开 ...
- iOS 7设计备忘单
With the release of iOS 7, app designers and developers will need to adjust their visual language to ...
- 卸载系统自动jdk
执行下面的代码可以看到当前各种JDK版本和配置: sudo update-alternatives --config java 卸载系统自动jdk [root@localhost soft]# r ...
- redhat7.0配置网卡
1.切换到网卡配置目录: cd /etc/sysconfig/network-scripts 2.编辑网卡信息 如 vim ifcfg-enpos3 TYPE=Ethernet #设备类型 BOOTP ...
- Mac MySQL 数据库配置(关系型数据库管理系统)
前言 MySQL 关系型数据库管理系统. 1.配置准备工作 1)配置数据库准备工作 下载相关软件 mysql-5.7.21-1-macos10.13-x86_64.dmg mysql-workbenc ...
- openssl命令行工具简介 - 指令x509
原文链接: http://blog.csdn.net/allwtg/article/details/4982507 openssl命令行工具简介 - 指令x509 用法: open ...