在spring中使用通用Mapper,抽象出通用的业务类BaseService

 
这里写一下spring中使用Mapper的方案,这也是项目中的最优方案; 
由于spring4增加了对泛型注入的支持,这个特性对于Mybatis的通用Mapper来说,非常的有用,可以直接在service中写Mapper


,通过BaseService 来实现通用的Service; 
Spring 抽象出Service方法– BaseService
public abstract class BaseService {
    // public abstract Mapper getMapper();


    //注入Mapper
    @Autowired
    private Mapper mapper;
    /**
     * 根据id查询数据
     * 
     * @param id
     * @return
     */
    public T queryById(Long id) {
        return mapper.selectByPrimaryKey(id);
    }


    /**
     * 查询所有数据
     * 
     * @return
     */
    public List queryAll() {
        return mapper.select(null);
    }


    /**
     * 根据条件查询一条数据,如果有多条数据会抛出异常
     * 
     * @param record
     * @return
     */
    public T queryOne(T record) {
        return mapper.selectOne(record);
    }


    /**
     * 根据条件查询数据列表
     * 
     * @param record
     * @return
     */
    public List queryListByWhere(T record) {
        return mapper.select(record);
    }


    /**
     * 分页查询
     * 
     * @param page
     * @param rows
     * @param record
     * @return
     */
    public PageInfo queryPageListByWhere(Integer page, Integer rows, T record) {
        // 设置分页条件
        PageHelper.startPage(page, rows);
        List list = this.queryListByWhere(record);
        return new PageInfo(list);
    }


    /**
     * 新增数据,返回成功的条数
     * 
     * @param record
     * @return
     */
    public Integer save(T record) {
        record.setCreated(new Date());
        record.setUpdated(record.getCreated());
            return mapper.insert(record);
        }


    /**
     * 新增数据,使用不为null的字段,返回成功的条数
     * 
     * @param record
     * @return
     */
    public Integer saveSelective(T record) {
    record.setCreated(new Date());
           record.setUpdated(record.getCreated());
            return mapper.insertSelective(record);
        }


    /**
     * 修改数据,返回成功的条数
     * 
     * @param record
     * @return
     */
    public Integer update(T record) {
        return mapper.updateByPrimaryKey(record);
    }


    /**
     * 修改数据,使用不为null的字段,返回成功的条数
     * 
     * @param record
     * @return
     */
    public Integer updateSelective(T record) {
    record.setUpdated(new Date());
            return mapper.updateByPrimaryKeySelective(record);
        }


    /**
     * 根据id删除数据
     * 
     * @param id
     * @return
     */
    public Integer deleteById(Long id) {
    record.setUpdated(new Date());
            return mapper.deleteByPrimaryKey(id);
        }


    /**
     * 批量删除
     * @param clazz
     * @param property
     * @param values
     * @return
     */
    public Integer deleteByIds(Class clazz, String property, List values) {
        Example example = new Example(clazz);
        example.createCriteria().andIn(property, values);
        return mapper.deleteByExample(example);
    }


    /**
     * 根据条件做删除
     * 
     * @param record
     * @return
     */
    public Integer deleteByWhere(T record) {
        return mapper.delete(record);
    }


}


用ItemCartService继承BaseService来实现业务需求:


@Service
public class ItemCartService extends BaseService{
    //这里可以没有任何业务代码,当然也可以根据业务需求,写出相应的代码


}


接下来看如何在Controller中调用Service: 
  
@Autowired
ItemCartService itemCartService;


@RequestMapping(method=RequestMethod.GET)
public ResponseEntity> queryItemCart(@RequestParam(value="id" ,defaultValue="0")
                 Long parentId) {
    try{
        //构造查询条件
        ItemCart record=new ItemCart();
        record.setParentId(parentId);
        List itemCarts=itemCartService.queryListByWhere(record);


        if(itemCarts == null || itemCarts.isEmpty()){
            return ResponseEntity.status(HttpStatus.Not_FOUND).body(null);
        }
        return ResponseEntity.ok(itemCarts);
        }catch(Exception e){
            e.printStackTrace();
        }
        return ResponseEntity.staus(HttpStatus.INTERNAL_SERVER_ERROR).body(null);
}


你可能感兴趣的:(spring,mvc,mapper,ssh)