zoukankan      html  css  js  c++  java
  • Spring Boot jpa Service层实现代码

    package com.fei.service.impl;
    
    import java.util.ArrayList;
    import java.util.List;
    
    import javax.persistence.criteria.CriteriaBuilder;
    import javax.persistence.criteria.CriteriaQuery;
    import javax.persistence.criteria.Predicate;
    import javax.persistence.criteria.Root;
    
    import org.springframework.beans.BeanUtils;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.data.domain.Page;
    import org.springframework.data.domain.Pageable;
    import org.springframework.data.jpa.domain.Specification;
    import org.springframework.stereotype.Service;
    
    import com.fei.NotFoundException;
    import com.fei.po.Blog;
    import com.fei.po.Type;
    import com.fei.repository.BlogRepository;
    import com.fei.service.BlogService;
    
    /**
     * Created by zxf on 2019年10月3日
     */
    @Service
    public class BlogServiceImpl implements BlogService {
    
    	@Autowired
    	private BlogRepository blogRepository;
    
    	/**
    	 * 根据id查询一条博客
    	 * 
    	 * @param id
    	 * @return
    	 */
    	@Override
    	public Blog getBlog(Long id) {
    		return blogRepository.findById(id).get();
    	}
    
    	/**
    	 * 多条件动态查询博客列表
    	 * 
    	 * @param pageable
    	 * @param blog
    	 * @return
    	 */
    	@Override
    	public Page<Blog> listBlog(Pageable pageable, Blog blog) {
    		return blogRepository.findAll(new Specification<Blog>() {
    
    			@Override
    			public Predicate toPredicate(Root<Blog> root, CriteriaQuery<?> cq, CriteriaBuilder cb) {
    				List<Predicate> predicates = new ArrayList<>();
    
    				String title = blog.getTitle();
    				if (!"".equals(title) && title != null) {
    					predicates.add(cb.like(root.<String>get("title"), "%" + title + "%"));
    				}
    
    				Long id = blog.getType().getId();
    				if (id != null) {
    					predicates.add(cb.equal(root.<Type>get("type").get("id"), id));
    				}
    
    				boolean isRecommend = blog.isRecommend();
    				if (isRecommend) {
    					predicates.add(cb.equal(root.<Boolean>get("recommend"), isRecommend));
    				}
    
    				cq.where(predicates.toArray(new Predicate[predicates.size()]));
    				return null;
    			}
    		}, pageable);
    	}
    
    	/**
    	 * 保存一条博客
    	 * 
    	 * @param blog
    	 * @return
    	 */
    	@Override
    	public Blog saveBlog(Blog blog) {
    		return blogRepository.save(blog);
    	}
    
    	/**
    	 * 更新一条博客,先根据id查出结果回显
    	 * 
    	 * @param id
    	 * @param blog
    	 * @return
    	 */
    	@Override
    	public Blog updateBlog(Long id, Blog blog) {
    		Blog b = blogRepository.findById(id).get();
    		if (b == null) {
    			throw new NotFoundException("你要更新的博客不存在!");
    		}
    
    		BeanUtils.copyProperties(b, blog);
    		return blogRepository.save(blog);
    	}
    
    	/**
    	 * 根据id删除一条博客
    	 * 
    	 * @param id
    	 */
    	@Override
    	public void deleteBlog(Long id) {
    		blogRepository.deleteById(id);
    	}
    
    }
    
    
  • 相关阅读:
    非域环境下搭建自动故障转移镜像无法将 ALTER DATABASE 命令发送到远程服务器实例的解决办法
    AWS 免费套餐
    SQL Server全时区转换
    SQL Server 连接问题案例解析(1)
    SQL Saturday活动再起
    SqlServerProxy的一些资料
    数据是企业的无价財富——爱数备份存储柜server的初体验(图文)
    JEECG第二期深入使用培训(报名截止2014-06-21)
    Java提高篇(三三)-----Map总结
    经常使用哈希函数的比較及其C语言实现
  • 原文地址:https://www.cnblogs.com/zxfei/p/11621124.html
Copyright © 2011-2022 走看看