package pwc.taxtech.atms.dao;

import java.util.List;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.session.RowBounds;
import pwc.taxtech.atms.MyMapper;
import pwc.taxtech.atms.entity.CitJournalEntryAdjust;
import pwc.taxtech.atms.entity.CitJournalEntryAdjustExample;

@Mapper
public interface CitJournalEntryAdjustMapper extends MyMapper {
    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table cit_journal_entry_adjust
     *
     * @mbg.generated
     */
    long countByExample(CitJournalEntryAdjustExample example);

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table cit_journal_entry_adjust
     *
     * @mbg.generated
     */
    int deleteByExample(CitJournalEntryAdjustExample example);

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table cit_journal_entry_adjust
     *
     * @mbg.generated
     */
    int deleteByPrimaryKey(Long id);

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table cit_journal_entry_adjust
     *
     * @mbg.generated
     */
    int insert(CitJournalEntryAdjust record);

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table cit_journal_entry_adjust
     *
     * @mbg.generated
     */
    int insertSelective(CitJournalEntryAdjust record);

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table cit_journal_entry_adjust
     *
     * @mbg.generated
     */
    List<CitJournalEntryAdjust> selectByExampleWithRowbounds(CitJournalEntryAdjustExample example, RowBounds rowBounds);

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table cit_journal_entry_adjust
     *
     * @mbg.generated
     */
    List<CitJournalEntryAdjust> selectByExample(CitJournalEntryAdjustExample example);

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table cit_journal_entry_adjust
     *
     * @mbg.generated
     */
    CitJournalEntryAdjust selectByPrimaryKey(Long id);

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table cit_journal_entry_adjust
     *
     * @mbg.generated
     */
    int updateByExampleSelective(@Param("record") CitJournalEntryAdjust record, @Param("example") CitJournalEntryAdjustExample example);

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table cit_journal_entry_adjust
     *
     * @mbg.generated
     */
    int updateByExample(@Param("record") CitJournalEntryAdjust record, @Param("example") CitJournalEntryAdjustExample example);

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table cit_journal_entry_adjust
     *
     * @mbg.generated
     */
    int updateByPrimaryKeySelective(CitJournalEntryAdjust record);

    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table cit_journal_entry_adjust
     *
     * @mbg.generated
     */
    int updateByPrimaryKey(CitJournalEntryAdjust record);

    /**
     * fetch data by citJournalAdjustList
     *
     * @param citJournalAdjustList
     * @return int
     */
    int insertBatch(List<CitJournalEntryAdjust> citJournalAdjustList);

    /**
     * fetch data by period orgList
     *
     * @param period
     * @param orgList
     * @return List<CitJournalEntryAdjust>
     */
    List<CitJournalEntryAdjust> sumAmountByCondition(@Param("period") String period, @Param("orgList") List<String> orgList);

    /**
     * fetch data by projectId
     *
     * @param projectId
     * @return List<CitJournalEntryAdjust>
     */
    List<CitJournalEntryAdjust> getJournalMerge(String projectId);
}