java注解@Transient的作用

@Transient标注的属性,不会被ORM框架映射到数据库中。

用于数据库表字段和java实体属性不一致的时候,标注在属性上使用。

例如时间段的查询 查询

Receipt

的createDate

那么可以在

Receipt

实体中加两个字段:

  //起始时间
@Transient
private Date startDate; //结束时间
@Transient
private Date endDate;

这两个字段并不会在数据库中出现。

但是前台传递过来的时间段,就可以使用这两个字段做接收,然后在JPA查询条件中,

在实体中加上下面这个方法:

package com.pisen.cloud.luna.ms.security.code.base.domain;

import org.apache.commons.lang3.StringUtils;
import org.springframework.data.jpa.domain.Specification; import javax.persistence.*;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Predicate;
import javax.persistence.criteria.Root;
import java.util.ArrayList;
import java.util.Date;
import java.util.List; /**
* 入库单
*/
@Entity
@Table(
uniqueConstraints = {
@UniqueConstraint(columnNames = "uid"),
@UniqueConstraint(columnNames = {"receiptCode","tenementId"})
},
indexes = {
@Index(columnList = "receiptCode")
}
)
public class Receipt { public static final Integer SOURCE_PAGE_ADD = 1; //入库单来源-页面新增 public static final Integer SOURCE_CODE_STORAGE= 2;//入库单来源-生码入库 public static final Integer SOURCE_PACKING_STORAGE = 3;//入库单来源-装箱入库 public static final Integer SOURCE_SCAN_CODE_STORAGE = 4;//入库单来源-扫码入库 public static final Integer STATUS_RECEIPT_CREATE_ING = 1;//入库状态-清单生成中 public static final Integer STATUS_RECEIPT_FAIL = 2;//入库状态-清单生成失败 public static final Integer STATUS_RECEIPT_COMPELETE = 3;//入库状态-已入库 @Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id; //主键 private String uid;//业务主键 private String createUid;// 创建人id private String createName;//入库单创建人 private Date createDate;// 入库单创建时间 入库日期 private String updateId;// 修改人id private Date updateDate;// 入库单修改时间 private String remark;//备注 private String receiptCode;// 入库单号 租户内唯一 private Integer receiptSource;// 入库单来源 private Integer receiptStatus;// 入库状态 private String tenementId;//租户ID private String depotId;//仓库ID private String receiptDepot;// 入库方仓库 仓库名称 private String depotAddress;//仓库地址 private String outerCode;//外部单号 暂时隐藏 //第几页
@Transient
private Integer pageNum = 0; //每页多少条
@Transient
private Integer pageSize = 10; //起始时间
@Transient
private Date startDate; //结束时间
@Transient
private Date endDate; public Long getId() {
return id;
} public void setId(Long id) {
this.id = id;
} public String getUid() {
return uid;
} public void setUid(String uid) {
this.uid = uid;
} public String getCreateUid() {
return createUid;
} public void setCreateUid(String createUid) {
this.createUid = createUid;
} public String getCreateName() {
return createName;
} public void setCreateName(String createName) {
this.createName = createName;
} public Date getCreateDate() {
return createDate;
} public void setCreateDate(Date createDate) {
this.createDate = createDate;
} public String getUpdateId() {
return updateId;
} public void setUpdateId(String updateId) {
this.updateId = updateId;
} public Date getUpdateDate() {
return updateDate;
} public void setUpdateDate(Date updateDate) {
this.updateDate = updateDate;
} public String getRemark() {
return remark;
} public void setRemark(String remark) {
this.remark = remark;
} public String getReceiptCode() {
return receiptCode;
} public void setReceiptCode(String receiptCode) {
this.receiptCode = receiptCode;
} public Integer getReceiptSource() {
return receiptSource;
} public void setReceiptSource(Integer receiptSource) {
this.receiptSource = receiptSource;
} public Integer getReceiptStatus() {
return receiptStatus;
} public void setReceiptStatus(Integer receiptStatus) {
this.receiptStatus = receiptStatus;
} public String getDepotAddress() {
return depotAddress;
} public void setDepotAddress(String depotAddress) {
this.depotAddress = depotAddress;
} public String getTenementId() {
return tenementId;
} public void setTenementId(String tenementId) {
this.tenementId = tenementId;
} public String getDepotId() {
return depotId;
} public void setDepotId(String depotId) {
this.depotId = depotId;
} public String getReceiptDepot() {
return receiptDepot;
} public void setReceiptDepot(String receiptDepot) {
this.receiptDepot = receiptDepot;
} public String getOuterCode() {
return outerCode;
} public void setOuterCode(String outerCode) {
this.outerCode = outerCode;
} public Integer getPageNum() {
return pageNum;
} public void setPageNum(Integer pageNum) {
this.pageNum = pageNum;
} public Integer getPageSize() {
return pageSize;
} public void setPageSize(Integer pageSize) {
this.pageSize = pageSize;
} public Date getStartDate() {
return startDate;
} public void setStartDate(Date startDate) {
this.startDate = startDate;
} public Date getEndDate() {
return endDate;
} public void setEndDate(Date endDate) {
this.endDate = endDate;
} //高级查询
public static Specification<Receipt> where(final Receipt receipt){ return new Specification<Receipt>() { @Override
public Predicate toPredicate(Root<Receipt> root, CriteriaQuery<?> query, CriteriaBuilder cb) { List<Predicate> predicates = new ArrayList<Predicate>(); //动态条件
String uid = receipt.getUid();
if(StringUtils.isNotBlank(uid)){
predicates.add(cb.equal(root.<String>get("uid"), uid));
} //入库单号
String receiptCode = receipt.getReceiptCode();
if (StringUtils.isNotBlank(receiptCode)) {
predicates.add(cb.equal(root.<String>get("receiptCode"), receiptCode));
} //入库单来源
Integer receiptSource = receipt.getReceiptSource();
if (receiptSource != null) {
predicates.add(cb.equal(root.<String>get("receiptSource"), receiptSource));
} //入库日期
Date startDate = receipt.getStartDate();
Date endDate = receipt.getEndDate();
if (startDate != null && endDate != null){
predicates.add(cb.between(root.get("createDate"),startDate,endDate));
} //入库状态
Integer receiptStatus = receipt.getReceiptStatus();
if (receiptStatus != null) {
predicates.add(cb.equal(root.<String>get("receiptStatus"), receiptStatus));
} //租户id
String tenementId = receipt.getTenementId();
if(StringUtils.isNotBlank(tenementId)){
predicates.add(cb.equal(root.<String>get("tenementId"), tenementId));
} return query.where(predicates.toArray(new Predicate[predicates.size()])).getRestriction();
}
}; } }
package com.pisen.cloud.luna.ms.security.code.base.domain;

import org.apache.commons.lang3.StringUtils;
import org.springframework.data.jpa.domain.Specification; import javax.persistence.*;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Predicate;
import javax.persistence.criteria.Root;
import java.util.ArrayList;
import java.util.Date;
import java.util.List; /**
* 入库单
*/
@Entity
@Table(
uniqueConstraints = {
@UniqueConstraint(columnNames = "uid"),
@UniqueConstraint(columnNames = {"receiptCode","tenementId"})
},
indexes = {
@Index(columnList = "receiptCode")
}
)
public class Receipt { public static final Integer SOURCE_PAGE_ADD = ; //入库单来源-页面新增 public static final Integer SOURCE_CODE_STORAGE= ;//入库单来源-生码入库 public static final Integer SOURCE_PACKING_STORAGE = ;//入库单来源-装箱入库 public static final Integer SOURCE_SCAN_CODE_STORAGE = ;//入库单来源-扫码入库 public static final Integer STATUS_RECEIPT_CREATE_ING = ;//入库状态-清单生成中 public static final Integer STATUS_RECEIPT_FAIL = ;//入库状态-清单生成失败 public static final Integer STATUS_RECEIPT_COMPELETE = ;//入库状态-已入库 @Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id; //主键 private String uid;//业务主键 private String createUid;// 创建人id private String createName;//入库单创建人 private Date createDate;// 入库单创建时间 入库日期 private String updateId;// 修改人id private Date updateDate;// 入库单修改时间 private String remark;//备注 private String receiptCode;// 入库单号 租户内唯一 private Integer receiptSource;// 入库单来源 private Integer receiptStatus;// 入库状态 private String tenementId;//租户ID private String depotId;//仓库ID private String receiptDepot;// 入库方仓库 仓库名称 private String depotAddress;//仓库地址 private String outerCode;//外部单号 暂时隐藏 //第几页
@Transient
private Integer pageNum = ; //每页多少条
@Transient
private Integer pageSize = ; //起始时间
@Transient
private Date startDate; //结束时间
@Transient
private Date endDate; public Long getId() {
return id;
} public void setId(Long id) {
this.id = id;
} public String getUid() {
return uid;
} public void setUid(String uid) {
this.uid = uid;
} public String getCreateUid() {
return createUid;
} public void setCreateUid(String createUid) {
this.createUid = createUid;
} public String getCreateName() {
return createName;
} public void setCreateName(String createName) {
this.createName = createName;
} public Date getCreateDate() {
return createDate;
} public void setCreateDate(Date createDate) {
this.createDate = createDate;
} public String getUpdateId() {
return updateId;
} public void setUpdateId(String updateId) {
this.updateId = updateId;
} public Date getUpdateDate() {
return updateDate;
} public void setUpdateDate(Date updateDate) {
this.updateDate = updateDate;
} public String getRemark() {
return remark;
} public void setRemark(String remark) {
this.remark = remark;
} public String getReceiptCode() {
return receiptCode;
} public void setReceiptCode(String receiptCode) {
this.receiptCode = receiptCode;
} public Integer getReceiptSource() {
return receiptSource;
} public void setReceiptSource(Integer receiptSource) {
this.receiptSource = receiptSource;
} public Integer getReceiptStatus() {
return receiptStatus;
} public void setReceiptStatus(Integer receiptStatus) {
this.receiptStatus = receiptStatus;
} public String getDepotAddress() {
return depotAddress;
} public void setDepotAddress(String depotAddress) {
this.depotAddress = depotAddress;
} public String getTenementId() {
return tenementId;
} public void setTenementId(String tenementId) {
this.tenementId = tenementId;
} public String getDepotId() {
return depotId;
} public void setDepotId(String depotId) {
this.depotId = depotId;
} public String getReceiptDepot() {
return receiptDepot;
} public void setReceiptDepot(String receiptDepot) {
this.receiptDepot = receiptDepot;
} public String getOuterCode() {
return outerCode;
} public void setOuterCode(String outerCode) {
this.outerCode = outerCode;
} public Integer getPageNum() {
return pageNum;
} public void setPageNum(Integer pageNum) {
this.pageNum = pageNum;
} public Integer getPageSize() {
return pageSize;
} public void setPageSize(Integer pageSize) {
this.pageSize = pageSize;
} public Date getStartDate() {
return startDate;
} public void setStartDate(Date startDate) {
this.startDate = startDate;
} public Date getEndDate() {
return endDate;
} public void setEndDate(Date endDate) {
this.endDate = endDate;
} //高级查询
public static Specification<Receipt> where(final Receipt receipt){ return new Specification<Receipt>() { @Override
public Predicate toPredicate(Root<Receipt> root, CriteriaQuery<?> query, CriteriaBuilder cb) { List<Predicate> predicates = new ArrayList<Predicate>(); //动态条件
String uid = receipt.getUid();
if(StringUtils.isNotBlank(uid)){
predicates.add(cb.equal(root.<String>get("uid"), uid));
} //入库单号
String receiptCode = receipt.getReceiptCode();
if (StringUtils.isNotBlank(receiptCode)) {
predicates.add(cb.equal(root.<String>get("receiptCode"), receiptCode));
} //入库单来源
Integer receiptSource = receipt.getReceiptSource();
if (receiptSource != null) {
predicates.add(cb.equal(root.<String>get("receiptSource"), receiptSource));
} //入库日期
Date startDate = receipt.getStartDate();
Date endDate = receipt.getEndDate();
if (startDate != null && endDate != null){
predicates.add(cb.between(root.get("createDate"),startDate,endDate));
} //入库状态
Integer receiptStatus = receipt.getReceiptStatus();
if (receiptStatus != null) {
predicates.add(cb.equal(root.<String>get("receiptStatus"), receiptStatus));
} //租户id
String tenementId = receipt.getTenementId();
if(StringUtils.isNotBlank(tenementId)){
predicates.add(cb.equal(root.<String>get("tenementId"), tenementId));
} return query.where(predicates.toArray(new Predicate[predicates.size()])).getRestriction();
}
}; } }

【Java】java注解@Transient的作用, 配合JPA中时间段的查询的更多相关文章

  1. Spring Data JPA中的动态查询 时间日期

    功能:Spring Data JPA中的动态查询 实现日期查询 页面对应的dto类private String modifiedDate; //实体类 @LastModifiedDate protec ...

  2. JPA中的复杂查询

    JPQL全称Java Persistence Query Language 基于首次在EJB2.0中引入的EJB查询语言(EJB QL),Java持久化查询语言(JPQL)是一种可移植的查询语言,旨在 ...

  3. 【spring data jpa】jpa中使用in查询或删除 在@Query中怎么写 ,报错:org.springframework.expression.spel.SpelEvaluationException: EL1007E: Property or field 'goodsConfigUid' cannot be found on null 怎么处理

    示例代码如下: @Modifying @Transactional @Query("delete from GoodsBindConfigMapping gbc " + " ...

  4. hibernate 或jpa 中使用 AliasToBeanResultTransformer 自定义类型转换ResultTransformer 下划线转驼峰

    jpa中使用 sql查询时,返回结果直接转为实体bean的实现, 需要自定义一个ResultTransformer,如下, import java.util.Arrays; import org.ap ...

  5. Java基础学习总结(41)——JPA常用注解

    JPA全称Java Persistence API.JPA通过JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中.         JPA由EJB 3.0软件专 ...

  6. JAVA 注解的几大作用及使用方法详解

    JAVA 注解的几大作用及使用方法详解 (2013-01-22 15:13:04) 转载▼ 标签: java 注解 杂谈 分类: Java java 注解,从名字上看是注释,解释.但功能却不仅仅是注释 ...

  7. paip.Java Annotation注解的作用and 使用

    paip.Java Annotation注解的作用and 使用 作者Attilax 艾龙,  EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog. ...

  8. JAVA 注解的几大作用及使用方法详解【转】

    java 注解,从名字上看是注释,解释.但功能却不仅仅是注释那么简单.注解(Annotation) 为我们在代码中添加信息提供了一种形式化的方法,是我们可以在稍后 某个时刻方便地使用这些数据(通过 解 ...

  9. java transient关键字作用,使用场景。

    java transient关键字作用,使用场景. 2016年08月31日 15:31:10 阅读数:4280 transient的作用及使用方法,官方解释为: Variables may be ma ...

随机推荐

  1. static_cast AND dynamic_cast

    类型转换是一种机制,让程序员能够暂时或永久性改变编译器对对象的解释.注意,这并不意味着程序员改变了对象本身,而只是改变了对对象的解释. 在很多情况下,类型转换是合理的需求,可解决重要的兼容问题.因此, ...

  2. gulp入门1

    1. 下载.安装git(https://git-scm.com/downloads),学会使用命令行. 2. 下载.安装node.js(https://nodejs.org/en/),现在node.j ...

  3. 软考——(1)J2SE

    我们先从Java说起,简单的说,Java是一种面向对象的程序设计语言,可跨平台使用. 与之前学习的程序设计语言相比,最值得一提的就是Java的两种核心机制:Java虚拟机和垃圾回收机制. 1)虚拟机 ...

  4. CPU封装技术介绍

    所谓“CPU封装技术”是一种将集成电路用绝缘的塑料或陶瓷材料打包的技术.以CPU为例,我们实际看到的体积和外观并不是真正的CPU内核的大小和面貌,而是CPU内核等元件经过封装后的产品. CPU封装对于 ...

  5. poj 1743 Musical Theme (后缀数组+二分法)

    Musical Theme Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 16162   Accepted: 5577 De ...

  6. 三十道DP练习(持续更新)(pw:DP)

    前言: 话说DP这种纯考思维的题目,总是让我很伤脑筋,一些特别简单的DP我都常常做不出来,所以革命从现在(2018-05-01)开始,努力多刷点DP的练习-. 1.顺序对齐(align) 时间:201 ...

  7. P3531 [POI2012]LIT-Letters

    题目描述 Little Johnny has a very long surname. Yet he is not the only such person in his milieu. As it ...

  8. JNDI连接数据库的详细步骤 以及简要的c3po数据库连接的配置

    第一步在tomcat的context.xml文件中配置数据源:context.xml的路径形式是:D:\Program Files (x86)\apache-tomcat-6.0.44\conf\co ...

  9. 如何从oracle官网中下载The java language specification(java 语言规范)

    第一步: 第二步: 第三步:下面这个图在这个页面的下方,所以你只要一直往下看,直到看到下图的文字为止: 第四步: 第五步: 这样你就可以成功下载该java 语言规范的pdf了. 它直接下载的网址为: ...

  10. centos dhcp获取不到ip解决方法 Bringing up interface eth0: Device eth0 does not seem to be present,delaying initialization.

    1.删除文件: /etc/udev/rules.d/70-persistent-net.rules 2.编辑 /etc/sysconfig/network-scripts/ifcfg-eth0 删除H ...