com.sicheng.common.persistence.CrudDao Maven / Gradle / Ivy
/**
* 本作品使用 木兰公共许可证,第2版(Mulan PubL v2) 开源协议,请遵守相关条款,或者联系sicheng.net获取商用授权。
* Copyright (c) 2016 SiCheng.Net
* This software is licensed under Mulan PubL v2.
* You can use this software according to the terms and conditions of the Mulan PubL v2.
* You may obtain a copy of Mulan PubL v2 at:
* http://license.coscl.org.cn/MulanPubL-2.0
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PubL v2 for more details.
*/
package com.sicheng.common.persistence;
import com.sicheng.common.persistence.wrapper.Wrapper;
import org.apache.ibatis.annotations.Param;
import java.util.List;
/**
* 标题: DAO支持类实现
* 描述:
* 公司: 思程科技 www.sicheng.net
*
* @param
* @author zhaolei
* @date 2016年5月15日 下午8:47:13
*/
public interface CrudDao extends BaseDao {
/**
* 获取单条数据
*
* @param id 主键
* @return
*/
public T selectById(@Param(value = "id") Long id);
/**
* 查询 select * from a where id in(…)
*
* @param list 主键集合
* @return
*/
public List selectByIdIn(@Param(value = "list") List> list);
/**
* 查询数据列表,如果需要分页,请设置分页对象,如:entity.setPage(new Page());
*
* @param wrapper 查询条件,可为null。或new一个Wrapper对象,用于控制order by 排序、控制del_flag、控制distinct
* 入参为null,或入参为new一个Wrapper对象但无属性值,会查全表
* @param page 分页,null表示不分页
* @return
*/
public List selectByWhere(@Param(value = "p") Page page, @Param(value = "w") Wrapper wrapper);
/**
* 查询所有数据列表
*
* @param wrapper 可为null。或new一个Wrapper对象,用于控制order by 排序、控制del_flag、控制distinct
* @return
*/
public List selectAll(@Param(value = "w") Wrapper wrapper);
/**
* 插入数据
* 如果要在entity中带回自增长生成的主键值,mybatis的xml中要添加
*
* @param entity
* @return 受影响的行数
*/
public int insert(@Param(value = "entity") T entity);
/**
* 插入,只把非空的值插入到对应的字段
* 如果要在entity中带回自增长生成的主键值,mybatis的xml中要添加
*
* @param entity
* @return 受影响的行数
*/
public int insertSelective(@Param(value = "entity") T entity);
/**
* 根据主键更新记录,更新除了主键的所有字段
*
* @param entity
* @return 受影响的行数
*/
public int updateById(@Param(value = "entity") T entity);
/**
* 根据条件更新记录,更新除了主键的所有字段
*
* @param entity 数据实体,用于存储数据,这些数据将被update到表中
* @param wrapper 条件,用于where条件,找出符合条件的数据。入参为null,或入参为new一个Wrapper对象但无属性值,执行sql时会报错,防止更新全表
* @return 受影响的行数
*
* 注意:wrapper.entity.setDelFlag(null);把del_flag设为null,表示del_flag不做为条件查询,请你根据业务情况自己把握
*/
public int updateByWhere(@Param(value = "entity") T entity, @Param(value = "w") Wrapper wrapper);
/**
* 根据主键更新记录,只把非空的值更到对应的字段
*
* @param entity 数据实体,用于存储数据,这些数据将被update到表中
* @return 受影响的行数
*/
public int updateByIdSelective(@Param(value = "entity") T entity);
/**
* 根据条件更新记录,只把非空的值更到对应的字段
*
* @param entity 数据实体,用于存储数据,这些数据将被update到表中
* @param wrapper 条件,用于where条件,找出符合条件的数据。入参为null,或入参为new一个Wrapper对象但无属性值,执行sql时会报错,防止更新全表
* @return 受影响的行数
*
* 注意:wrapper.entity.setDelFlag(null);把del_flag设为null,表示del_flag不做为条件查询,请你根据业务情况自己把握
*/
public int updateByWhereSelective(@Param(value = "entity") T entity, @Param(value = "w") Wrapper wrapper);
/**
* 删除数据
* (如果有del_flag字段,就逻辑删除,更新del_flag字段为1表示删除)
* (如果无del_flag字段,就物理删除)
*
* @param id 主键
* @return 受影响的行数
*/
public int deleteById(@Param(value = "id") Long id);
/**
* 根据主键批量删除记录
*
* @param list 一批主键
* @return
*/
public int deleteByIdIn(@Param(value = "list") List