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);
}
对mybastis 的理解2--BaseDao接口方法声明
时间: 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