常见的springdatajpa
可以理解为JPA规范的再次封装抽象,底层还是使用了Hibernate的JPA技术实现,引用JPQL(Java Persistence Query Language)查询语言,属于Spring整个生态体系的一部分。随着Spring Boot和Spring Cloud在市场上的流行,Spring Data JPA也逐渐进入大家的视野,它们组成有机的整体,使用起来比较方便,加快了开发的效率,使开发者不需要关心和配置更多的东西,完全可以沉浸在Spring的完整生态标准实现下。JPA上手简单,开发效率高,对对象的支持比较好,又有很大的灵活性,市场的认可度越来越高。
JPA是Java Persistence API的简称,中文名为Java持久层API,是JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中。
常见的增删改查
在提供者中定义方法
import com.itzz.springcloudprovider.dao.UserRepository;
import com.itzz.springcloudprovider.pojo.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Example;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.jws.soap.SOAPBinding;
import java.util.List;
@RestController
public class UserController {
@Autowired
private UserRepository userRepository;
@GetMapping("user/{id}")
public User findById(@PathVariable(value = "id") Integer id){
return userRepository.getOne(id);
}
//restful传多个参
@GetMapping("search/{id}/{username}/{name}")
public User search(@PathVariable(value = "id") Integer id,@PathVariable("username") String username,@PathVariable("name") String name){
return userRepository.getOne(id);
}
@GetMapping("search2")
public User search2(Integer id,String username,String name){
return userRepository.getOne(id);
}
/*
搜索,返回集合
*/
@RequestMapping("/findList/{username}/{name}")
public List<User> findList(@PathVariable("username") String username,@PathVariable("name") String name){
//不太严谨,比如没有判断传入的值是否为空啊之类,不想写
User user = new User();
user.setUsername(username);
user.setName(name);
List<User> users = userRepository.findAll(Example.of(user));
return users;
}
/*
新增数据
*/
@RequestMapping("/save/{id}/{username}/{name}")
public User findList(@PathVariable("id") Integer id, @PathVariable("username") String username, @PathVariable("name") String name){
User user = new User();
user.setUsername(username);
user.setName(name);
userRepository.saveAndFlush(user);
return user;
}
/*
更新
*/
@RequestMapping("/update/{username}/{name}/{id}")
public User update(@PathVariable("username") String username ,@PathVariable("name")String name ,@PathVariable("id")Integer id){
User user = new User();
user.setUsername(username);
user.setName(name);
user.setId(id);
userRepository.saveAndFlush(user);
return user;
}
/*
删除
*/
@RequestMapping("/delete/{id}")
public User update(@PathVariable("id")Integer id){
userRepository.deleteById(id);
return null;
}
}
2 测试
访问通过username和name查询
新增
修改
删除
自定义查询语句(通过姓名模糊匹配)
在控制层加入方法
/*
模糊搜索 返回集合
*/
@RequestMapping("/findByName/{name}")
public List<User> findByName(@PathVariable("name")String name){
List<User> list = userRepository.findByNameLike(name);
return list;
}
在dao接口中定义
@Repository
public interface UserRepository extends JpaRepository<User,Integer> {
/*
hql 语句 表名 -- 类名
* --- 别名
*/
@Query(value = "select u from User u where u.name like %?1% ")
List<User> findByNameLike(String name);
}
hql语句
表名 – 类名
* — 别名
测试:
到这里springcloud就基本结束了。
星光不问赶路人,岁月不负有心人