对mybastis 的理解2--BaseDao接口方法声明

package org.xnat.dao;
 
import java.util.List;
import java.util.Map;
 
import org.apache.ibatis.annotations.Param;
import org.springframework.stereotype.Component;
import org.xnat.dao.util.AutoMap;
import org.xnat.dao.util.Page;
 
 
/**
 * 不直接用此baseDao 外部访问数据 用baseDaoUtil_v{1,2...}
 * @author xnat
 *
 */
@Component
public interface BaseDao {
    /**
     * 存入一条记录
     */
    public Integer insert(@Param("tableName")String tableName, @Param("list")List<AutoMap> list);
    /**
     * 存入一条记录 保存 自增长键的值到map 中的autoKey
     */
    public Integer insert_v1_2(Map<String, Object> map);
    /**
     * select_v4
     * @param tableName 表名
     * @param selectFields 要查询的字段
     * @param conditions 查询的条件
     * @param group 分组
     * @param havingSql 分组having Sql语句
     * @param sort 排序条件
     * @param page 分页查询
     * @return
     */
    public List<Map<String, Object>> select_v4(@Param("tableName") String tableName,  
            @Param("selectFields")List<String> selectFields,
            @Param("conditions")List<AutoMap> conditions, @Param("group")List<String> group, @Param("havingSql") String havingSql,  
            @Param("sort") List<AutoMap> sort, @Param("page")Page page);
    
    public List<Map<String, Object>> select_v4_2(@Param("tableName") String tableName,  
            @Param("selectFields")List<String> selectFields,
            @Param("conditionSql")String conditionSql, @Param("group")List<String> group, @Param("havingSql") String havingSql,  
            @Param("sort") List<AutoMap> sort, @Param("page")Page page);
    
    /**
     * 自定义sql查询
     * @param sql
     * @return
     */
    public List<Map<String, Object>> selectSql(@Param("sql")String sql);
    
    
    public int delete_v3(@Param("tableName")String tableName,  
            @Param("conditions")List<AutoMap> conditions);
    public int delete_v3_2(@Param("tableName")String tableName,  
            @Param("conditionSql")String conditionSql);
 
    public int update_v2(@Param("tableName")String tableName, @Param("list") List<AutoMap> list, @Param("conditions")List<AutoMap> conditions);
    public int update_v2_2(@Param("tableName")String tableName, @Param("list") List<AutoMap> list, @Param("conditionSql")String conditionSql);
    /**
     * 根据一个实体查询总数
     * @param  
     * @return
     */
    public int getTotal(@Param("tableName")String tableName, @Param("conditions") List<AutoMap> conditions);
    /**
     * 根据一个实体查询总数
     * @param  
     * @return
     */
    public int getTotal_v1_2(@Param("tableName")String tableName, @Param("conditionSql")String conditionSql);
    
    /**
     * 统计一个字段所有值的和
     * @param tableName
     * @param fieldName
     * @param conditions
     * @return
     */
    public long countField(@Param("tableName")String tableName, @Param("fieldName")String fieldName, @Param("conditions") List<AutoMap> conditions);
}

时间: 2024-10-10 01:49:19

对mybastis 的理解2--BaseDao接口方法声明的相关文章

Java语言程序设计 上机实验4 掌握声明接口、一个类实现接口的声明和使用方法

Java语言程序设计 上机实验4 实验目的: 理解接口的作用,理解接口和实现接口的类的关系,掌握声明接口.一个类实现接口的声明和使用方法:熟悉Java语言包和实用包中的常用类. 实验内容:(*)为选做 声明圆柱体类Cylinder,继承椭圆类Ellipse(实现周长Perimeter接口和面积Area接口),为圆柱体类设计较为全面的构造方法,并实现体积Volume接口,计算表面积和体积. 将Java的若干关键字(15个以上)保存在一个字符串数组中,对其按升序排列,再采用顺序查找和二分法查找,判断

深入理解Java的接口和抽象类(转)

深入理解Java的接口和抽象类 对于面向对象编程来说,抽象是它的一大特征之一.在Java中,可以通过两种形式来体现OOP的抽象:接口和抽象类.这两者有太多相似的地方,又有太多不同的地方.很多人在初学的时候会以为它们可以随意互换使用,但是实际则不然.今天我们就一起来学习一下Java中的接口和抽象类.下面是本文的目录大纲: 一.抽象类 二.接口 三.抽象类和接口的区别 若有不正之处,请多多谅解并欢迎批评指正,不甚感激. 请尊重作者劳动成果,转载请标明原文链接: http://www.cnblogs.

(转载)深入理解java的接口和抽象类

本文转自地址:http://www.cnblogs.com/dolphin0520/p/3811437.html 作者:海子 出处:http://www.cnblogs.com/dolphin0520/ 深入理解Java的接口和抽象类 对于面向对象编程来说,抽象是它的一大特征之一.在Java中,可以通过两种形式来体现OOP的抽象:接口和抽象类.这两者有太多相似的地方,又有太多不同的地方.很多人在初学的时候会以为它们可以随意互换使用,但是实际则不然.今天我们就一起来学习一下Java中的接口和抽象类

深入理解Java之接口

1. 为什么使用接口 Java中的接口是一组对需求的描述.例如,以下是Comparable<T>接口的定义: public interface Comparable<T> { int compareTo(T o); } Comparable<T>接口中定义了一个compareTo方法,这个方法就是它所描述的需求.若我们想调用Arrays.sort方法对一个People对象数组进行比较,那么People对象必须是”可比较的”,即People类需要实现Comparable&

深入理解Java虚拟机笔记---方法调用

方法调用并不等同于方法执行,方法调用阶段唯一的任务就是确定调用方法的版本(即调用哪一个方法),暂时还不涉及方法内部的具体运行过程.在程序运行时,进行方法调用是最普遍.最频繁的操作.在Class文件的编译过程中不包含传统编译中的连接步骤,一切方法调用在Class文件里存储的都只是符号引用,而不是方法在实际运行时内存布局中的入口地址(相当于直接引用).这个特性给Java带来了更强大的动态扩展能力,但也使得Java方法的调用过程变得相对复杂,需要在类加载期间甚至到运行期间才能确定目标方法的直接引用.

【转】深入理解Java的接口和抽象类

深入理解Java的接口和抽象类 对于面向对象编程来说,抽象是它的一大特征之一.在Java中,可以通过两种形式来体现OOP的抽象:接口和抽象类.这两者有太多相似的地方,又有太多不同的地方.很多人在初学的时候会以为它们可以随意互换使用,但是实际则不然.今天我们就一起来学习一下Java中的接口和抽象类.下面是本文的目录大纲: 一.抽象类 二.接口 三.抽象类和接口的区别 一.抽象类 在了解抽象类之前,先来了解一下抽象方法.抽象方法是一种特殊的方法:它只有声明,而没有具体的实现.抽象方法的声明格式为:

Java基础__慕课网学习(24):深入理解抽象类与接口(转)

深入理解Java的接口和抽象类 对于面向对象编程来说,抽象是它的一大特征之一.在Java中,可以通过两种形式来体现OOP的抽象:接口和抽象类.这两者有太多相似的地方,又有太多不同的地方.很多人在初学的时候会以为它们可以随意互换使用,但是实际则不然.今天我们就一起来学习一下Java中的接口和抽象类.下面是本文的目录大纲: 一.抽象类 二.接口 三.抽象类和接口的区别 一.抽象类 在了解抽象类之前,先来了解一下抽象方法.抽象方法是一种特殊的方法:它只有声明,而没有具体的实现.抽象方法的声明格式为:

深入理解Java的接口和抽象类 _摘抄

http://www.cnblogs.com/dolphin0520/p/3811437.html 原文 深入理解Java的接口和抽象类 对于面向对象编程来说,抽象是它的一大特征之一.在Java中,可以通过两种形式来体现OOP的抽象:接口和抽象类.这两者有太多相似的地方,又有太多不同的地方.很多人在初学的时候会以为它们可以随意互换使用,但是实际则不然.今天我们就一起来学习一下Java中的接口和抽象类.下面是本文的目录大纲: 一.抽象类 二.接口 三.抽象类和接口的区别 若有不正之处,请多多谅解并

深入理解Java Callable接口

概述Callable和Runnbale一样代表着任务,区别在于Callable有返回值并且可以抛出异常.其使用如下: public class CallableDemo { static class SumTask implements Callable<Long> { @Override public Long call() throws Exception { long sum = 0; for (int i = 0; i < 9000; i++) { sum += i; } ret