spring boot系列(五)spring boot 配置spring data jpa (查询方法)
接着上面spring boot系列(四)spring boot 配置spring data jpa 保存修改方法继续做查询的测试:
1 创建UserInfo实体类,代码和https://www.cnblogs.com/kxm87/p/9273555.html中的一样。
2 创建数据库操作类相当于dao层,主要创建一个接口UserRepository,继承JpaRepository接口即可。本代码中主要都是自定义方法。
使用findXX 或者countXX(这两个不用编写sql,jpa会自动生成) 或者@Query 编写JPQL语句 或者原生语句
package com.cfj.ceshi.jpa.repository; import java.util.List; import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param; import com.cfj.ceshi.jpa.domain.UserInfo; public interface UserRepository extends JpaRepository<UserInfo, Integer> { List<UserInfo> findByUserNameNotNull(); //不为空 List<UserInfo> findByUserNameIsNull(); //为空 /**
* 按照姓名=?查询
* 最终转成sql语句为:select userinfo0_.id as id1_0_, userinfo0_.age as age2_0_,
* userinfo0_.user_name as user_nam3_0_ from user_info userinfo0_
* where userinfo0_.user_name=?
* @param name
* @return
*/
UserInfo findByUserName(String name);//用名字直接查询 /**
* 按照 name = ? and age = ? 查询
* 最终转成sql语句为:select userinfo0_.id as id1_0_, userinfo0_.age as age2_0_,
* userinfo0_.user_name as user_nam3_0_ from user_info userinfo0_
* where userinfo0_.user_name=? and userinfo0_.age=?
* @param name
* @param age
* @return
*/
UserInfo findByUserNameAndAge(String name,String age);//and /**
* 按照 id between ? and ? 查询
* 最终解析sql语句为:select userinfo0_.id as id1_0_, userinfo0_.age as age2_0_,
* userinfo0_.user_name as user_nam3_0_ from user_info userinfo0_
* where userinfo0_.id between ? and ?
* @param idStrat
* @param idEnd
* @return
*/
List<UserInfo> findByIdBetween(Integer idStrat,Integer idEnd); /**
* 按照年龄统计行数
* 最终解析sql语句为:select count(userinfo0_.id) as col_0_0_ from user_info userinfo0_ where userinfo0_.age=?
* @param age
* @return
*/
Integer countByAge(String age); /**
* 目的是类似 user_name like '%dd%'这种查询 所以必须用Containing
* 这样会把%%包含在里面 如果直接是like 则不包含%
* @param name
* @return
*/
List<UserInfo> findByUserNameContaining(String name); /**
* 按照username in ()
* 最终解析sql语句为:select userinfo0_.id as id1_0_, userinfo0_.age as age2_0_,
* userinfo0_.user_name as user_nam3_0_ from user_info userinfo0_
* where userinfo0_.user_name in (? , ?) * @return
*/
List<UserInfo> findByUserNameIn(List<String> list); /**
* 使用JPA sql查询 注意 1 对应userName 2 对应age ?号中的数字和参数表中从左向右顺序一一对应
* @param userName
* @param age
* @return
*/
@Query(value = "select u from UserInfo u where u.userName=?1 and u.age = ?2")
UserInfo getUserInfo(String userName,String age); /**
* 使用JPA sql查询 注意 1 对应userName 2 对应age ?号中的数字和参数表中从左向右顺序一一对应
* 返回name
* @param userName
* @param age
* @return
*/
@Query(value = "select u.userName from UserInfo u where u.userName=?1 and u.age = ?2")
String getUserInfoTwo(String userName,String age); /**
* 使用原生sql查询
* @param userName
* @param age
* @return
*/
@Query(value = "select * from user_info u where u.user_name=?1 and u.age = ?2" ,nativeQuery = true)
UserInfo getUserInfoThree(String userName,String age); /**
* 用参数方式
* @param userName
* @param age
* @return
*/
@Query(value = "select u.userName from UserInfo u where u.userName=:name and u.age = :age")
String getUserInfoFour(@Param("name")String userName,@Param("age")String age); /**
* jpa sql
* @param age
* @param userName
* @return
*/
@Modifying
@Query(value = "update UserInfo u set u.age = ?1 where u.userName = ?2")
Integer updateUserInfo(String age,String userName); /**
* 原生sql
* @param age
* @param userName
* @return
*/
@Modifying
@Query(value = "update user_info set age = ?1 where user_name = ?2",nativeQuery = true)
Integer updateUserInfoOne(String age,String userName); /**
* 删除方法
* @param userName
* @return
*/
@Modifying
@Query(value = "delete from UserInfo u where u.userName = ?1")
Integer deleteUserInfo(String userName); }
3 创建service接口和它的实现类,代码如下:
package com.cfj.ceshi.jpa.service;
import java.util.List;
import com.cfj.ceshi.jpa.domain.UserInfo;
public interface UserService {
public Integer save(UserInfo user);
public void delete(Integer id);
List<UserInfo> findByUserNameNotNull();
List<UserInfo> findByUserNameIsNull();
UserInfo findByUserName(String name);//用名字直接查询
UserInfo findByUserNameAndAge(String name,String age);//and
List<UserInfo> findByUserIdBetween(Integer idStrat,Integer idEnd);
Integer countByAge(String age);
List<UserInfo> findByUserNameContaining(String name);
List<UserInfo> findByUserNameIn(List<String> list);
UserInfo getUserInfo(String userName,String age);
String getUserInfoTwo(String userName,String age);
UserInfo getUserInfoThree(String userName,String age);
String getUserInfoFour(String userName,String age);
Integer updateUserInfo(String age,String userName);
Integer updateUserInfoOne(String age,String userName);
Integer deleteUserInfo(String userName);
UserInfo findOne(Integer id);
List<UserInfo> findAll();
}
package com.cfj.ceshi.jpa.service.impl; import java.util.List; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import com.cfj.ceshi.jpa.domain.UserInfo;
import com.cfj.ceshi.jpa.repository.UserRepository;
import com.cfj.ceshi.jpa.service.UserService; @Service
@Transactional
public class UserServiceImpl implements UserService{ @Autowired
private UserRepository userRepository; @Override
public Integer save(UserInfo user) {
return userRepository.save(user).getId();
} @Override
public void delete(Integer id) {
userRepository.delete(id);
} @Override
public List<UserInfo> findByUserNameNotNull() {
return userRepository.findByUserNameNotNull();
} @Override
public List<UserInfo> findByUserNameIsNull() {
return userRepository.findByUserNameIsNull();
} @Override
public UserInfo findByUserName(String name) {
return userRepository.findByUserName(name);
} @Override
public UserInfo findByUserNameAndAge(String name, String age) {
return userRepository.findByUserNameAndAge(name, age);
} @Override
public List<UserInfo> findByUserIdBetween(Integer idStrat, Integer idEnd) {
return userRepository.findByIdBetween(idStrat, idEnd);
} @Override
public Integer countByAge(String age) {
return userRepository.countByAge(age);
} @Override
public List<UserInfo> findByUserNameContaining(String name) {
return userRepository.findByUserNameContaining(name);
} @Override
public List<UserInfo> findByUserNameIn(List<String> list) {
return userRepository.findByUserNameIn(list);
} @Override
public UserInfo getUserInfo(String userName, String age) {
return userRepository.getUserInfo(userName, age);
} @Override
public String getUserInfoTwo(String userName, String age) {
return userRepository.getUserInfoTwo(userName, age);
} @Override
public UserInfo getUserInfoThree(String userName, String age) {
return userRepository.getUserInfoThree(userName, age);
} @Override
public String getUserInfoFour(String userName, String age) {
return userRepository.getUserInfoFour(userName, age);
} @Override
public Integer updateUserInfo(String age, String userName) {
return userRepository.updateUserInfo(age, userName);
} @Override
public Integer updateUserInfoOne(String age, String userName) {
return userRepository.updateUserInfoOne(age, userName);
} @Override
public Integer deleteUserInfo(String userName) {
return userRepository.deleteUserInfo(userName);
} @Override
public UserInfo findOne(Integer id) {
return userRepository.findOne(id);
} @Override
public List<UserInfo> findAll() {
return userRepository.findAll();
} }
有删除或者修改的时候 service层一定要加上事务控制@Transactional,否则就会报错:Executing an update/delete query; nested exception is javax.persistence.TransactionRequiredException: Executing an update/delete query
4 创建控制类(controller)在spring boot 里面用web包表示,代码如下:
package com.cfj.ceshi.jpa.web; import java.util.ArrayList;
import java.util.List; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; import com.cfj.ceshi.jpa.domain.UserInfo;
import com.cfj.ceshi.jpa.service.UserService; @RestController
@RequestMapping("/userquery")
public class UserQueryWeb { @Autowired
private UserService userService; @RequestMapping("/checknull")
public String getUserInfoOne() {
String result = "id集合:[";
//List<UserInfo> list = userService.findByUserNameNotNull(); List<UserInfo> list = userService.findByUserNameIsNull(); for (int i = 0; i< list.size(); i++) {
UserInfo u = new UserInfo();
u = list.get(i);
result += u.getId().toString()+",";
}
result = result+"]";
return result; } /**
* 按照姓名=?查询
* 最终转成sql语句为:select userinfo0_.id as id1_0_, userinfo0_.age as age2_0_,
* userinfo0_.user_name as user_nam3_0_ from user_info userinfo0_
* where userinfo0_.user_name=?
* @param name
* @return
*/
@RequestMapping("/getByName")
public String getUserInfoByName(String name) {
return userService.findByUserName(name).toString(); } /**
* 按照 name = ? and age = ? 查询
* 最终转成sql语句为:select userinfo0_.id as id1_0_, userinfo0_.age as age2_0_,
* userinfo0_.user_name as user_nam3_0_ from user_info userinfo0_
* where userinfo0_.user_name=? and userinfo0_.age=?
* @param name
* @param age
* @return
*/
@RequestMapping("/getByNameAndAge")
public String getUserInfoByName(String name,String age) {
return userService.findByUserNameAndAge(name, age).toString(); } /**
* 按照 id between ? and ? 查询
* 最终解析sql语句为:select userinfo0_.id as id1_0_, userinfo0_.age as age2_0_,
* userinfo0_.user_name as user_nam3_0_ from user_info userinfo0_
* where userinfo0_.id between ? and ?
* @param idStrat
* @param idEnd
* @return
*/
@RequestMapping("/getByIdBetween")
public String getUserInfoTwo(Integer idStrat, Integer idEnd) { String result = "id集合:[";
List<UserInfo> list = userService.findByUserIdBetween(idStrat, idEnd); for (int i = 0; i< list.size(); i++) {
UserInfo u = new UserInfo();
u = list.get(i);
result += u.getId().toString()+",";
}
result = result+"]";
return result; }
/**
* 按照年龄统计行数
* 最终解析sql语句为:select count(userinfo0_.id) as col_0_0_ from user_info userinfo0_ where userinfo0_.age=?
* @param age
* @return
*/
@RequestMapping("/getByCount")
public Integer getCount(String age) {
return userService.countByAge(age); } /**
* 目的是类似 user_name like '%dd%'这种查询 所以必须用Containing
* 这样会把%%包含在里面 如果直接是like 则不包含%
* @param name
* @return
*/
@RequestMapping("/getByUserNameLike")
public String getUserNameLike(String name) { String result = "id集合:[";
List<UserInfo> list = userService.findByUserNameContaining(name); for (int i = 0; i< list.size(); i++) {
UserInfo u = new UserInfo();
u = list.get(i);
result += u.getId().toString()+",";
}
result = result+"]";
return result; } /**
* 按照username in ()
* 最终解析sql语句为:select userinfo0_.id as id1_0_, userinfo0_.age as age2_0_,
* userinfo0_.user_name as user_nam3_0_ from user_info userinfo0_
* where userinfo0_.user_name in (? , ?) * @return
*/
@RequestMapping("/getByUserNameIn")
public String getUserNameIn() { String result = "id集合:[";
List<String> arrylist = new ArrayList<String>();
arrylist.add("w");
arrylist.add("ww");
List<UserInfo> list = userService.findByUserNameIn(arrylist); for (int i = 0; i< list.size(); i++) {
UserInfo u = new UserInfo();
u = list.get(i);
result += u.getId().toString()+",";
}
result = result+"]";
return result; } /*以下使用@Query查询*/ //使用JPA sql查询 注意 1 对应userName 2 对应age ?号中的数字和参数表中从左向右顺序一一对应
@RequestMapping("/testquery")
public String getUserNameByNameAndAge() { return userService.getUserInfo("rrr", "333").toString(); } //使用JPA sql查询 注意 1 对应userName 2 对应age ?号中的数字和参数表中从左向右顺序一一对应 返回name
@RequestMapping("/testquerytwo")
public String getUserNameByNameAndAgeTwo(String name,String age) { return userService.getUserInfoTwo(name, age); } // 使用原生sql查询
@RequestMapping("/testquerythree")
public String getUserNameByNameAndAgeThree() { return userService.getUserInfo("rrr", "333").toString(); } //使用参数方式 @Param("name")
@RequestMapping("/testqueryfour")
public String getUserNameByNameAndAgeFour(String name,String age) { return userService.getUserInfoFour(name, age); } //jpa sql 更新
@RequestMapping("/updateUserInfo")
public String updateUserInfo(String age,String name) { return userService.updateUserInfo(age, name).toString(); } //原生sql 更新
@RequestMapping("/updateUserInfoOne")
public String updateUserInfoOne(String age,String name) { return userService.updateUserInfoOne(age, name).toString(); }
//删除
@RequestMapping("/deleteUserInfo")
public String deleteUserInfo(String name) { return userService.deleteUserInfo(name).toString(); } //按照id查询 使用spring data jpa接口中的findOne方法
@RequestMapping("/getOne")
public String getOne(Integer id) {
return userService.findOne(id).toString();
} //按照id查询 使用spring data jpa接口中的findAll方法
@RequestMapping("/getAll")
public String getAll() {
String result = "id集合:[";
List<UserInfo> list = userService.findAll(); for (int i = 0; i< list.size(); i++) {
UserInfo u = new UserInfo();
u = list.get(i);
result += u.getId().toString()+",";
}
result = result+"]";
return result;
} }
5 使用postman工具测试
以上都是查询方法,所有用postman方法测试的时候,使用GET方式,然后选择URL栏旁边的Params设置传参,如下图:

本项目码云地址:
https://gitee.com/kaixinmao/jpa_lianxi/tree/master/jpa
spring boot系列(五)spring boot 配置spring data jpa (查询方法)的更多相关文章
- Spring Data JPA 查询方法支持的关键字
Table 2.3. Supported keywords inside method names Keyword Sample JPQL snippet And findByLastnameAndF ...
- Spring Boot系列(四):Spring Boot源码解析
一.自动装配原理 之前博文已经讲过,@SpringBootApplication继承了@EnableAutoConfiguration,该注解导入了AutoConfigurationImport Se ...
- Spring Boot 2 (五):Docker Compose + Spring Boot + Nginx + Mysql 实践
Spring Boot 2 (五):Docker Compose + Spring Boot + Nginx + Mysql 实践 Spring Boot + Nginx + Mysql 是实际工作中 ...
- Spring Boot系列(三):Spring Boot整合Mybatis源码解析
一.Mybatis回顾 1.MyBatis介绍 Mybatis是一个半ORM框架,它使用简单的 XML 或注解用于配置和原始映射,将接口和Java的POJOs(普通的Java 对象)映射成数据库中的记 ...
- Spring cloud系列教程第十篇- Spring cloud整合Eureka总结篇
Spring cloud系列教程第十篇- Spring cloud整合Eureka总结篇 本文主要内容: 1:spring cloud整合Eureka总结 本文是由凯哥(凯哥Java:kagejava ...
- 【tmos】spring data jpa 创建方法名进行简单查询
参考链接 spring data jpa 创建方法名进行简单查询:http://www.cnblogs.com/toSeeMyDream/p/6170790.html
- spring data jpa查询部分字段、多余附加字段
spring data jpa查询部分字段 第一种方法:使用 model 查询时转化 首先建立一个 model ,写上自己想要查询的字段,然后写上构造函数,这步很重要,因为spring jpa 转化时 ...
- 【HANA系列】SAP HANA XS使用Data Services查询CDS实体【二】
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列]SAP HANA XS使用Dat ...
- 【HANA系列】SAP HANA XS使用Data Services查询CDS实体【一】
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列]SAP HANA XS使用Dat ...
随机推荐
- python 3.4.3 安装pygame
之前一直都是用的python3.5,后来接触了pygame,又被python3.5的打包折磨的死去活来,后来干脆用python 3.4.3. 我之前安装轮子都是直接打开cmd,然后 pip3 inst ...
- Web Api(1)
由于在学习Web Api没有了解过MVC,觉得有些吃力.很多基础的东西都会一并记录下来. Web API 的意思是使用HTTP协议并通过网络调用的API. API的意思软件外部接口. 在实际的开发中, ...
- SpringBoot读取Resource下文件的几种方式
https://www.jianshu.com/p/7d7e5e4e8ae3 最近在项目中涉及到Excle的导入功能,通常是我们定义完模板供用户下载,用户按照模板填写完后上传:这里模板位置resour ...
- 基于Hexo的个人博客搭建(上)
没有废话,直接开始. 1. 环境配置 —1.1 node.js安装 https://nodejs.org/en/download/ 下载最新版本即可,然后无脑安装(除了选安装目录的时候),为了保证安装 ...
- Redis 配置连接池,redisTemplate 操作多个db数据库,切换多个db,解决JedisConnectionFactory的设置连接方法过时问题。(转)
环境 springmvc jdk1.8 maven redis.properties配置文件 #redis setting redis.host=localhost redis.port=6379 r ...
- 6 RESTful规范
https://www.cnblogs.com/alice-bj/p/9258121.html 1.什么是RESTful REST与技术无关,代表的是一种软件架构风格,REST是Representat ...
- 对webview的研究--------引用
简要的说,webview能够在移动应用中开辟出一个窗口,在里面显示html页面,css以及js代码也可以被解析执行,它使用的是我们熟悉的webkit内核.android和ios都有相应的API,所以写 ...
- 2019牛客暑期多校训练营(第八场)A 单调栈
题意 给一个\(n*m\)的01矩阵,找有多少个全1子矩阵不被其他全1子矩阵包括. 分析 用单调栈找到的全1子矩阵是不能向上扩展和向右扩展的,只需判断该子矩阵能否向左和向下扩展,若四个方向都不能扩展, ...
- 关于int main(int argc,char* argv[])详解
平时在VS的环境下,主函数总会看到这两个参数,今天突然很想知道这两个参数的原理以及作用,因此查了下资料.真心受教了. 下面的博文是在百度空间看一位大神的,原文链接:http://hi.baidu.co ...
- MySQL_(Java)分页查询MySQL中的数据
MySQL_(Java)使用JDBC向数据库发起查询请求 传送门 MySQL_(Java)使用JDBC创建用户名和密码校验查询方法 传送门 MySQL_(Java)使用preparestatement ...