Spring Boot - Spring Data
- 使用JPA
- 虽然JPA是一个标准,但spring中一般就是使用hibernate实现的
- 使用JPA(Java Persistence API,Java持久化API,是个规范,其实是借助Hibernate实现的)操作数据库,使用其CrudRepository接口。
- 数据库建好后,表会在使用时自动创建。
- 依赖是通过Gradle的dependencies中加入compile('org.springframework.boot:spring-boot-starter-data-jpa'),会简介引用一些其他的包如spring.rabbit-1.7.8.RELEASE.jar等
- 也可能是通过引入上层的配置
- application.properties中配置数据库信息,如果是Cloud Foundry等平台,app部署后的环境变量中如果有同名参数则会覆盖properties文件
# postgresql
spring.datasource.driverClassName=org.postgresql.Driver
spring.datasource.url=jdbc:postgresql://localhost:5432/amp
spring.datasource.username=postgres
spring.datasource.password=deb.deb
spring.jpa.database=POSTGRESQL
spring.jpa.database-platform=org.hibernate.dialect.PostgresPlusDialect
spring.jpa.show-sql=false
spring.jpa.hibernate.ddl-auto=update
* 定义用户POJO(算是数据库表的映射类)
* 没有表、索引等时,会自动创建
* 会用到一些数据库相关的注解,如@Entity(name = "assignment")、@Table、@Index、@NoArgsConstructor、@Id、@GeneratedValue(strategy = GenerationType.AUTO)、@Column(name = "tenant_id", nullable = false)、、
@Entity(name = "assignment")
@Table(indexes = {
@Index(name = AMPShiftCalendarConstants.IDX_TENANT_ID_ASSET_ID_ASSIGNMENT_START_DATE, columnList = "tenant_id, asset_id, assignment_start_date"),
@Index(name = AMPShiftCalendarConstants.IDX_TENANT_ID_ASSIGNMENT_START_DATE, columnList = "tenant_id, assignment_start_date") })
@NoArgsConstructor
@Getter
@Setter
public class Assignment {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "assignment_id")
private Long assignmentId;
@Column(name = "tenant_id", nullable = false)
private String tenantId;
@Column(name = "asset_id", nullable = false)
private String assetId;
@Column(name = "content", columnDefinition = "TEXT")
private String content;
@Column(name = "assignment_start_date", columnDefinition = "timestamp with time zone", nullable = false)
private Timestamp assignmentStartDate;
@Column(name = "inserted_date", columnDefinition = "timestamp with time zone", nullable = false)
private Timestamp insertedDate;
@Enumerated(EnumType.STRING)
@Column(name = "status", nullable = false)
private AssignmentStatus status;
public Assignment(String tenantId, String assetId, ShiftCalendar content, Timestamp assignmentStartDate, Timestamp insertedDate, AssignmentStatus status) {
this.tenantId = tenantId;
this.assetId = assetId;
this.setShiftCalendar(content);
this.assignmentStartDate = assignmentStartDate;
this.insertedDate = insertedDate;
this.status = status;
}
public ShiftCalendar getShiftCalendar() {
return content != null ? Misc.deserializeSafeJson(content, ShiftCalendar.class) : null;
}
public void setShiftCalendar(ShiftCalendar template) {
Check.notNull(template, "shiftCalendar");
this.content = Misc.serializeSafeJson(template);
}
@Override
public String toString() {
return "Assignment [assignment_id=" + assignmentId + ", asset=" + assetId + ", assignmentStatus=" + status + ", content=" + content
+ ", assignment_start_date=" + assignmentStartDate + "]";
}
}
* 自定义Repository类
* 基于表及其映射类,也可以直接用CrudRepository
* 用于数据库操作,有点类似于.NET的EF的DBContext类,基类已实现了部分通用简单的基于数据库表的操作,复杂的还是要自己拼sql(用xml或动态sql或者如下的方式)。
* 其实还有其他更具体的功能更强的子类可以用,比如可以分页什么的。
* getAllByTenantIdAndAssetId这种其实是利用了JPA的命名查询功能,可以指定通过哪些列来查询,还可以使用like功能。
* @Query注解其实是JPA提供查询语言的JPQL,与Hibernate提供的HQL十分接近。
* JPA(Hibernate)其实慢慢被mybatis替代了??
@Repository
public interface AssignmentRepository extends CrudRepository<Assignment, Long> {
List<Assignment> getAllByTenantId(String tenantId);
List<Assignment> getAllByTenantIdAndAssetId(String tenantId, String assetId);
@Query(value = "" +
" SELECT " +
"DISTINCT a.asset_id AS asset_id" +
" FROM assignment a " +
" WHERE a.tenant_id = :tenant_id" +
" AND a.assignment_start_date < :end_date" +
" AND a.status='ACTIVE'",
nativeQuery = true)
List<String> getAllAssetsWithActiveWorkplan(
@Param("tenant_id") String tenantId,
@Param("end_date") Timestamp endDate);
}
public interface MissingWorkPieceRepository extends CrudRepository<MissingWorkPiece, Long> {
List<MissingWorkPiece> getAllByAssetIdAndTenantIdAndDateBetweenOrderByDateDesc(String assetId, String tenantId, Timestamp from, Timestamp to);
Optional<MissingWorkPiece> getByAssetIdAndTenantIdAndDate(String assetId, String tenantId, Timestamp date);
@Transactional
void deleteByAssetIdAndTenantIdAndDate(String assetId, String tenantId, Timestamp date);
}
Spring Boot - Spring Data的更多相关文章
- Spring Boot + Spring Data + Elasticsearch实例
Spring Boot + Spring Data + Elasticsearch实例 学习了:https://blog.csdn.net/huangshulang1234/article/detai ...
- 255.Spring Boot+Spring Security:使用md5加密
说明 (1)JDK版本:1.8 (2)Spring Boot 2.0.6 (3)Spring Security 5.0.9 (4)Spring Data JPA 2.0.11.RELEASE (5)h ...
- 256.Spring Boot+Spring Security: MD5是加密算法吗?
说明 (1)JDK版本:1.8 (2)Spring Boot 2.0.6 (3)Spring Security 5.0.9 (4)Spring Data JPA 2.0.11.RELEASE (5)h ...
- Spring Boot+Spring Security:获取用户信息和session并发控制
说明 (1)JDK版本:1.8(2)Spring Boot 2.0.6(3)Spring Security 5.0.9(4)Spring Data JPA 2.0.11.RELEASE(5)hiber ...
- springboot成神之——spring boot,spring jdbc和spring transaction的使用
本文介绍spring boot,spring jdbc和spring transaction的使用 项目结构 依赖 application model层 mapper层 dao层 exception层 ...
- spring Boot+spring Cloud实现微服务详细教程第二篇
上一篇文章已经说明了一下,关于spring boot创建maven项目的简单步骤,相信很多熟悉Maven+Eclipse作为开发常用工具的朋友们都一目了然,这篇文章主要讲解一下,构建spring bo ...
- spring Boot+spring Cloud实现微服务详细教程第一篇
前些天项目组的大佬跟我聊,说项目组想从之前的架构上剥离出来公用的模块做微服务的开发,恰好去年的5/6月份在上家公司学习了国内开源的dubbo+zookeeper实现的微服务的架构.自己平时对微服务的设 ...
- Spring boot +Spring Security + Thymeleaf 认证失败返回错误信息
[Please make sure to select the branch corresponding to the version of Thymeleaf you are using] Stat ...
- Cola Cloud 基于 Spring Boot, Spring Cloud 构建微服务架构企业级开发平台
Cola Cloud 基于 Spring Boot, Spring Cloud 构建微服务架构企业级开发平台: https://gitee.com/leecho/cola-cloud
- spring boot + spring batch 读数据库文件写入文本文件&读文本文件写入数据库
好久没有写博客,换了一家新公司,原来的公司用的是spring,现在这家公司用的是spring boot.然后,项目组布置了一个任务,关于两个数据库之间的表同步,我首先想到的就是spring batch ...
随机推荐
- Spring框架的特点
1. 为什么要学习Spring的框架 * 方便解耦,简化开发 * Spring就是一个大工厂,可以将所有对象创建和依赖关系维护,交给Spring管理 * AOP编程的支持 * Spring提供面向切面 ...
- oracle使用 merge 更新或插入数据
OracleCC++C# 总结下.使用merge比传统的先判断再选择插入或更新快很多. 1)主要功能 提供有条件地更新和插入数据到数据库表中 如果该行存在,执行一个UPDATE操作,如果是一个新行, ...
- CreateMutex用法
1. CreateMutex只是创建了一把锁, 这把锁你用来锁门还是锁抽屉还是锁你对象的内裤都由你自己决定. 2. lpName是指定这把锁的名字. 你要不给这把锁取个名字都可以. 只是有了相 ...
- thrift相关资源
官网资料,具有各语言的例子 https://thrift.apache.org/tutorial/ https://thrift.apache.org/tutorial/py
- jQuery获得元素位置offset()和position()的区别
jQuery获得元素位置offset()和position()的区别 jQuery 中有两个获取元素位置的方法offset()和position(),这两个方法之间有什么异同 offset(): 获取 ...
- java中配置自定义拦截器中exclude-mapping path是什么意思?
<mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/**"/>//过滤全部请求 & ...
- 2018.10.13 bzoj4008: [HNOI2015]亚瑟王(概率dp)
传送门 马上2点考初赛了,心里有点小紧张. 做道概率dp压压惊吧. 话说这题最开始想错了. 最开始的方法是考虑f[i][j]f[i][j]f[i][j]表示第iii轮出牌为jjj的概率. 然后用第ii ...
- 2018.09.12 hdu2473Junk-Mail Filter(并查集)
传送门 一开始开题还以为是平衡树. 仔细想了一想并查集就可以了. 合并操作没什么好说的. 删除操作:对于每个点记录一个pos值表示原来的点i现在的下标是什么. 每次删除点i是就新建一个点cnt,然后令 ...
- ABP框架系列之七:(About-关于ABP)
Considerations Source codes Contributors Contact ASP.NET Boilerplate is designed to help us to devel ...
- Linux命令:sed
简介 sed 是一种在线编辑器,它一次处理一行内容.处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的 ...