开始之前你必须在项目配置好数据库,本文使用的spring boot,相比spring,spring boot省去了很多各种对以来组件复杂的配置,直接在pom配置组件,完后会自动帮我们导入组件

        <!-- 导入SpringDataJPA的坐标 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<!-- 连接数据库驱动 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<!-- 连接池 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.0.9</version>
</dependency>

  然后在src/main/resources下,新建application.properties文件,用配置连接数据库的参数

spring.datasource.driverClassName=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/test_db
spring.datasource.username=root
spring.datasource.password=123 spring.datasource.type=com.alibaba.druid.pool.DruidDataSource spring.jpa.hibernate.ddl-auto=update
spring.jpa.show-sql=true spring.http.multipart.maxFileSize=1024Mb
spring.http.multipart.maxRequestSize=1034Mb

  另外的,由于jpa操作是模型驱动的,所以需要对操作的表定义模型

package cn.yitiantian.test.model;

import org.hibernate.annotations.DynamicInsert;
import org.hibernate.annotations.DynamicUpdate; import javax.persistence.*; @DynamicUpdate
@DynamicInsert
@Entity
@Table(name = "user")
public class user {
@Id
@GeneratedValue
@Column(name = "id")
Integer id; @Column(name = "name")
String name; @Column(name = "caption")
Integer captionId; public Integer getId() {
return id;
} public void setId(Integer id) {
this.id = id;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public Integer getCaptionId() {
return captionId;
} public void setCaptionId(Integer captionId) {
this.captionId = captionId;
}
}

  这样,我们就可以开始操作数据库了

基本查询

  基本查询中分为两种,一种是spring data默认已经实现,一种根据查询的方法来自动解析成SQL

  默认已经实现的方法是一些最基本的增删改查方法,如findAll()、delete(user)

  而自定义简单查询,则是通过关键词和属性组合而成,然后jpa会自动解析成SQL语句执行,如findByCaptionId、findByNameOrderById

  更多基本方法和关键词使用详见 jpa

自定义SQL查询

  除了基本查询,jpa还是支持自定义SQL,只要使用@Query注解,如果涉及到动数据,还要加上Modifying,另外还支持事务操作

  更多基本方法和关键词使用详见 jpa

public interface EmpRepository extends JpaRepository<Emp, Integer>,JpaSpecificationExecutor<Emp>{

	//查询name(驼峰式名称)
public List<Emp> findByName(String name);
public List<Emp> findByNameAndGender(String name,String gender);
public List<Emp> findByTelephoneLike(String telphone); @Query("from Emp where name = ?")
public List<Emp> queryName(String name); @Query(value="select * from t_emp where name = ?",nativeQuery=true)
public List<Emp> queryName2(String name); @Query("update Emp set address = ? where id = ?")
@Modifying // 进行修改操作
public void updateAddressById(String address,Integer id);
}

  当然,如果你想在执行SQL语句前,就想定义好一个模型来接收查询的数据,你还可以这么做

  第一步,先定义一个数据库操作的扩展类

public interface MergedVersionRepositoryExtend {
public List<MergedVersion> findVersionByTableId();
}

  第二步,再让数据库操作类集成这个扩展类

public interface MergedVersionRepository extends MergedVersionRepositoryExtend {

}

  第三步,定义获取数据方法,并封装到模型里

@Repository
public class MergedVersionRepositoryImpl implements MergedVersionRepositoryExtend { @Autowired
private JdbcTemplate jdbcTemplate; @Override
public List<MergedVersion> findVersionByTableId() {
String sql = "SELECT DISTINCT\n" +
"\tversionT.version AS version,\n" +
"\ttableT.id AS id,\n" +
"\ttableT.`name` AS name\n" +
"FROM\n" +
"\tu_showinfo_table AS tableT\n" +
"LEFT OUTER JOIN u_showinfo_detail_table AS detailT ON detailT.table_id=tableT.id\n" +
"LEFT OUTER JOIN u_showinfo_property AS propertyT ON propertyT.detail_table_id=detailT.id\n" +
"LEFT OUTER JOIN u_showinfo_version AS versionT ON versionT.property_id=propertyT.id\n" +
"ORDER BY\n" +
"\tversionT.version"; List<MergedVersion> versionList = jdbcTemplate.query(sql, new MergedVersionMapper());
return versionList; }
}

  第四步,定义模型

public class MergedVersion {
private int tableId;
private String tableName;
private String version; public int getTableId() {
return tableId;
} public void setTableId(int tableId) {
this.tableId = tableId;
} public String getTableName() {
return tableName;
} public void setTableName(String tableName) {
this.tableName = tableName;
} public String getVersion() {
return version;
} public void setVersion(String version) {
this.version = version;
}
}

  第五步,定义将查询数据注入模型里的方法

public class MergedVersionMapper implements RowMapper<MergedVersion> {

    @Override
public MergedVersion mapRow(ResultSet rs, int rowNum) throws SQLException {
MergedVersion mergedVersion = new MergedVersion(); mergedVersion.setTableId(rs.getInt("id"));
mergedVersion.setTableName(rs.getString("name"));
mergedVersion.setVersion(rs.getString("version")); return mergedVersion;
}
}

  

复杂查询

  排序

    @Override
public List<ShowInfoTable> findAllTable() {
Sort sort = new Sort(Sort.Direction.ASC, "id");
return showInfoTableRepository.findAll(sort);
}

  除了在查询方法里实现排序,对结果集进行排序,可以这么做

class UserComparator implements Comparator {

    @Override
public int compare(Object o1, Object o2) {
User prop1 = (User)o1;
User prop2 = (User)o2; return prop1.getId().compareTo(prop2.getId());
}
}

  调用(Collections.sort也可以直接支持列表排序)

                UserComparator comparator = new UserComparator();
Collections.sort(users, comparator);

  

  分页和限制查询

    更多基本方法和关键词使用详见 jpa

  

一篇搞定spring Jpa操作数据库的更多相关文章

  1. 2021升级版微服务教程6—Ribbon使用+原理+整合Nacos权重+实战优化 一篇搞定

    2021升级版SpringCloud教程从入门到实战精通「H版&alibaba&链路追踪&日志&事务&锁」 教程全目录「含视频」:https://gitee.c ...

  2. 第12章—使用NoSQL数据库—使用MongoDB+Jpa操作数据库

    使用MongoDB+Jpa操作数据库 SpringData还提供了对多种NoSQL数据库的支持,包括MongoDB;neo4j和redis.他不仅支持自动化的repository,还支持基于模板的数据 ...

  3. 170622、springboot编程之JPA操作数据库

    JPA操作数据库 什么事JAP?JPA全称Java Persistence API.JPA通过JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中. 1.在pom ...

  4. 3步轻松搞定Spring Boot缓存

    作者:谭朝红 前言 本次内容主要介绍基于Ehcache 3.0来快速实现Spring Boot应用程序的数据缓存功能.在Spring Boot应用程序中,我们可以通过Spring Caching来快速 ...

  5. 一篇搞定RSA加密与SHA签名|与Java完全同步

    基础知识 什么是RSA?答:RSA是一种非对称加密算法,常用来对传输数据进行加密,配合上数字摘要算法,也可以进行文字签名. RSA加密中padding?答:padding即填充方式,由于RSA加密算法 ...

  6. 一文搞定 Spring Data JPA

    Spring Data JPA 是在 JPA 规范的基础上进行进一步封装的产物,和之前的 JDBC.slf4j 这些一样,只定义了一系列的接口.具体在使用的过程中,一般接入的是 Hibernate 的 ...

  7. 【项目实践】一文带你搞定Spring Security + JWT

    以项目驱动学习,以实践检验真知 前言 关于认证和授权,R之前已经写了两篇文章: [项目实践]在用安全框架前,我想先让你手撸一个登陆认证 [项目实践]一文带你搞定页面权限.按钮权限以及数据权限 在这两篇 ...

  8. 一文搞定Spring Boot + Vue 项目在Linux Mysql环境的部署(强烈建议收藏)

    本文介绍Spring Boot.Vue .Vue Element编写的项目,在Linux下的部署,系统采用Mysql数据库.按照本文进行项目部署,不迷路. 1. 前言 典型的软件开发,经过" ...

  9. Spring入门(十五):使用Spring JDBC操作数据库

    在本系列的之前博客中,我们从没有讲解过操作数据库的方法,但是在实际的工作中,几乎所有的系统都离不开数据的持久化,所以掌握操作数据库的使用方法就非常重要. 在Spring中,操作数据库有很多种方法,我们 ...

随机推荐

  1. (五)Oracle学习笔记—— 视图

    1. 视图简介 视图是虚表,没有具体物理数据,是通过实体表的一种计算映射逻辑.主要就是为了方便和数据安全. 2. 视图作用 简化数据操作:视图可以简化用户处理数据的方式. 着重于特定数据:不必要的数据 ...

  2. 数组传到后台 string[] 获取

    调试的 时候js  断点到后台 js上面也可以查看 传到后台的数据 方便查看~~

  3. elasticsearch 索引设置

    索引设置 你可以通过很多种方式来自定义索引行为,你可以阅读Index Modules reference documentation,但是: 提示: Elasticsearch 提供了优化好的默认配置 ...

  4. nodejs 获取指定路径下所有的文件夹名

    示例:获取 ./components 下所有的文件夹名称 let components = [] const files = fs.readdirSync('./components') files. ...

  5. centos/rhel下实现nginx自启动脚本实例

    1. 建立脚本文件nginxd [root@could]# vi /etc/init.d/nginxd 插入以下内容   #!/bin/bash # # chkconfig: - 85 15 # de ...

  6. Eclipse RCP应用开发(概念)

    学习Eclipse RCP应用开发,对其中一些相关的概念需要了解. 让我们在讲解概念前先思考两个问题. 问题一.什么是Eclipse 大部分同学会回答eclipse是IBM公司开发的java集成开发环 ...

  7. angular总结控制器的三种主要职责: 为应用中的模型设置初始状态 通过$scope对象把数据模型或函数行为暴露给视图 监视模型的变化,做出相应的动作

    m1.双向数据绑定: <body> <div ng-app ng-init="user.name='world'"> <h1>使用NG实现双边数 ...

  8. Ubuntu安装Sun JDK

    Ubuntu 14.04 下安装 Sun JDK 1.8.0 1.下载JDK http://www.oracle.com/technetwork/java/javase/downloads/jdk8- ...

  9. 实战Java虚拟机之中的一个“堆溢出处理”

    从今天開始.我会发5个关于java虚拟机的小系列: 实战Java虚拟机之中的一个"堆溢出处理" 实战Java虚拟机之二"虚拟机的工作模式" 实战Java虚拟机之 ...

  10. hdu5334(2015多校4)--Virtual Participation(构造)

    题目链接:pid=5334">点击打开链接 题目大意:给出一个数字k,要求做出一个长度小于等于10^5的序列.该序列中不同样的连续子序列有k个. 构造啊,.,,,,一点辙都没有 使用连 ...