springcloud中常见的springdatajpa

常见的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就基本结束了。

星光不问赶路人,岁月不负有心人

猜你喜欢

转载自blog.csdn.net/qq_39095899/article/details/107469151
今日推荐