1.BaseDao接口:

//使用BaseDao<T> 泛型 ,在service中注入的时候,只需要将T换为对应的bean即可

public interface BaseDao<T> {

public int save(T t);

public int update(String hql, Object[] paramlist);

public int delete(String hql, Object[] paramlist);

public int countAll(String hql, Object[] paramlist);

public int countAll(String hql, String key, Object[] ids);

public int countAll(String hql, Object[] paramlist, String key, Object[] ids);
    
    public int countAllBysql(String hql, T t, Object[] paramlist, String key, Object[] ids);

public Map<String, Object> get(String hql);

public Map<String, Object> get(String hql, Object[] paramlist);

public int updateBySql(String hql, Object[] paramlist);

public List<Map<String, Object>> listAll(String hql, String parkey,
            Object[] ids);

public List<Map<String, Object>> listAllPage(String hql, String parkey,
            Object[] ids, Object[] paramlistPage);

public List<Map<String, Object>> listAllPage(String hql,
            Object[] paramlist, String key, Object[] ids, Object[] paramlistPage);
    
    public List<Map<String, Object>> listAllPageBysql(String hql,T t,
            Object[] paramlist, String key, Object[] ids, Object[] paramlistPage);

public List<Map<String, Object>> listAll(String hql);

public List<T> listAllBySql(String hql, T t, Object[] paramlist);

public List<Map<String, Object>> listAll(String hql, Object[] paramlist);

public List<T> listObject(String hql, Object[] paramlist);

public List<Map<String, Object>> listAllPage(String hql,
            Object[] paramlist, Object[] paramlistPage);

public List<Map<String, Object>> listAllPage(String hql, String key,
            Object[] ids);

public List<Map<String, Object>> listAllPage(String hql,
            Object[] paramlist, String key, Object[] ids);
}

2.接口的实现 BaseDaoimpl

@Repository("baseDao")
public class BaseDaoImpl<T> implements BaseDao<T> {

protected static final Logger LOGGER = LoggerFactory
            .getLogger(BaseDaoImpl.class);

@Autowired
    @Qualifier("sessionFactory")
    private SessionFactory sessionFactory;

public Session getSession() {
        return sessionFactory.getCurrentSession();
    }

@Override
    public int save(T t) {
        return (int) getSession().save(t);
    }

@Override
    public int update(String hql, Object[] paramlist) {
        Query query = getSession().createQuery(hql);
        setParameters(query, paramlist);
        return query.executeUpdate();
    }

@Override
    public int updateBySql(String hql, Object[] paramlist) {
        Query query = getSession().createSQLQuery(hql);
        setParameters(query, paramlist);
        return query.executeUpdate();
    }

@Override
    public int delete(String hql, Object[] paramlist) {
        Query query = getSession().createQuery(hql);
        setParameters(query, paramlist);
        return query.executeUpdate();
    }

@SuppressWarnings("unchecked")
    @Override
    public int countAll(String hql, Object[] paramlist) {
        Query query = getSession().createQuery(hql);
        setParameters(query, paramlist);
        List<Map<String, Object>> results = query.list();
        return results.size();
    }

@SuppressWarnings("unchecked")
    @Override
    public int countAll(String hql, String key, Object[] ids) {
        Query query = getSession().createQuery(hql);
        setInParameters(query, key, ids);
        List<Map<String, Object>> results = query.list();
        return results.size();
    }

@SuppressWarnings("unchecked")
    @Override
    public int countAll(String hql, Object[] paramlist, String key, Object[] ids) {
        Query query = getSession().createQuery(hql);
        setParameters(query, paramlist);
        setInParameters(query, key, ids);
        List<Map<String, Object>> results = query.list();
        return results.size();
    }
    
    @SuppressWarnings("unchecked")
    @Override
    public int countAllBysql(String hql, T t, Object[] paramlist, String key, Object[] ids) {
        Query query = getSession().createSQLQuery(hql).addEntity(t.getClass());
        setParameters(query, paramlist);
        setInParameters(query, key, ids);
        List<Map<String, Object>> results = query.list();
        return results.size();
    }

@SuppressWarnings("unchecked")
    @Override
    public List<Map<String, Object>> listAll(String hql) {
        Query query = getSession().createQuery(hql);
        List<Map<String, Object>> results = query.list();
        return results;
    }

@SuppressWarnings("unchecked")
    @Override
    public List<Map<String, Object>> listAll(String hql, Object[] paramlist) {
        Query query = getSession().createQuery(hql);
        setParameters(query, paramlist);
        List<Map<String, Object>> results = query.list();
        return results;
    }

@SuppressWarnings("unchecked")
    @Override
    public List<Map<String, Object>> listAll(String hql, String key,
            Object[] ids) {
        Query query = getSession().createQuery(hql);
        setInParameters(query, key, ids);
        List<Map<String, Object>> results = query.list();
        return results;
    }

@SuppressWarnings("unchecked")
    @Override
    public List<T> listAllBySql(String hql, T t, Object[] paramlist) {
        Query query = getSession().createSQLQuery(hql).addEntity(t.getClass());// ;
        setParameters(query, paramlist);
        List<T> results = query.list();
        return results;
    }

@SuppressWarnings("unchecked")
    @Override
    public List<T> listObject(String hql, Object[] paramlist) {
        Query query = getSession().createQuery(hql);
        setParameters(query, paramlist);
        List<T> results = query.list();
        return results;
    }

@SuppressWarnings("unchecked")
    @Override
    public List<Map<String, Object>> listAllPage(String hql,
            Object[] paramlist, Object[] paramlistPage) {
        Query query = getSession().createQuery(hql);
        setParameters(query, paramlist);
        query.setFirstResult(Integer.parseInt(paramlistPage[0] + ""));
        query.setMaxResults(Integer.parseInt(paramlistPage[1] + ""));
        List<Map<String, Object>> results = query.list();
        return results;
    }

@SuppressWarnings("unchecked")
    @Override
    public List<Map<String, Object>> listAllPage(String hql, String key,
            Object[] ids, Object[] paramlistPage) {
        Query query = getSession().createQuery(hql);
        setInParameters(query, key, ids);
        query.setFirstResult(Integer.parseInt(paramlistPage[0] + ""));
        query.setMaxResults(Integer.parseInt(paramlistPage[1] + ""));
        List<Map<String, Object>> results = query.list();
        return results;
    }

@SuppressWarnings("unchecked")
    @Override
    public List<Map<String, Object>> listAllPage(String hql, String key,
            Object[] ids) {
        Query query = getSession().createQuery(hql);
        setInParameters(query, key, ids);
        List<Map<String, Object>> results = query.list();
        return results;
    }

@SuppressWarnings("unchecked")
    @Override
    public List<Map<String, Object>> listAllPage(String hql,
            Object[] paramlist, String key, Object[] ids, Object[] paramlistPage) {
        Query query = getSession().createQuery(hql);
        setParameters(query, paramlist);
        setInParameters(query, key, ids);
        query.setFirstResult(Integer.parseInt(paramlistPage[0] + ""));
        query.setMaxResults(Integer.parseInt(paramlistPage[1] + ""));
        List<Map<String, Object>> results = query.list();
        return results;
    }

@SuppressWarnings("unchecked")
    @Override
    public List<Map<String, Object>> listAllPageBysql(String hql,T t,
            Object[] paramlist, String key, Object[] ids, Object[] paramlistPage) {
        Query query = getSession().createSQLQuery(hql).addEntity(t.getClass());
        setParameters(query, paramlist);
        setInParameters(query, key, ids);
        query.setFirstResult(Integer.parseInt(paramlistPage[0] + ""));
        query.setMaxResults(Integer.parseInt(paramlistPage[1] + ""));
        List<Map<String, Object>> results = query.list();
        return results;
    }
    
    @SuppressWarnings("unchecked")
    @Override
    public Map<String, Object> get(String hql) {
        Map<String, Object> resultMap = new HashMap<String, Object>();
        Query query = getSession().createQuery(hql);
        List<Map<String, Object>> results = query.list();
        if (results.size() > 0) {
            resultMap = results.get(0);
        }
        return resultMap;
    }

@SuppressWarnings("unchecked")
    @Override
    public Map<String, Object> get(String hql, Object[] paramlist) {
        Map<String, Object> resultMap = new HashMap<String, Object>();
        Query query = getSession().createQuery(hql);
        setParameters(query, paramlist);
        List<Map<String, Object>> results = query.list();
        if (results.size() > 0) {
            resultMap = results.get(0);
        }
        return resultMap;
    }

protected void setParameters(Query query, Object[] paramlist) {
        if (paramlist != null) {
            for (int i = 0; i < paramlist.length; i++) {
                if (paramlist[i] instanceof Date) {
                    query.setTimestamp(i, (Date) paramlist[i]);
                } else if (paramlist[i] instanceof Double) {
                    query.setDouble(i, (double) paramlist[i]);
                } else {
                    query.setParameter(i, paramlist[i]);
                }
            }
        }
    }

protected void setInParameters(Query query, String key, Object[] ids) {
        if (ids.length > 0) {
            query.setParameterList(key, ids);
        }
    }

@SuppressWarnings("unchecked")
    @Override
    public List<Map<String, Object>> listAllPage(String hql,
            Object[] paramlist, String key, Object[] ids) {
        Query query = getSession().createQuery(hql);
        setParameters(query, paramlist);
        setInParameters(query, key, ids);
        List<Map<String, Object>> results = query.list();
        return results;
    }

//String hql :在service 中的hql语句     Object[] paramlist : hql中的字段,先用?占位    Object[] ids: 可以使用分页工具,等其他对数据的操作,一般也是用?来占位

}

Hql 中 dao 层 以及daoimpl 层的代码,让mvc 模式更直观简洁的更多相关文章

  1. view是视图层+action是控制层+service是业务层+dao是数据访问层。

  2. Java中Action层、Service层、Modle层和Dao层的功能区分

    一.Java中Action层.Service层.Modle层和Dao层的功能区分: 首先,这是现在最基本的分层方式,结合了SSH架构. modle层就是对应的数据库表的实体类.(即domain) Da ...

  3. java中Action层、Service层和Dao层的功能区分

    Action/Service/DAO简介: Action是管理业务(Service)调度和管理跳转的. Service是管理具体的功能的. Action只负责管理,而Service负责实施. DAO只 ...

  4. javaEE中关于dao层和services层的理解

    javaEE中关于dao层和services层的理解 入职已经一个多月了,作为刚毕业的新人,除了熟悉公司的项目,学习公司的框架,了解项目的一些业务逻辑之外,也就在没学到什么:因为刚入职, 带我的那个师 ...

  5. 一个项目中说系统分为表现层、控制层、逻辑层、DAO层和最终数据库五层架构-转

    表现层就是看到的东西,比如你现在看到的当前页面控制层就将你的请求从页面传到后台代码逻辑层就是处理你的请求的代码DAO层就是将数据存到数据库中的代码数据库就是数据库了,存东西用的 ,DAO层就是将访问数 ...

  6. [转]JAVA中Action层, Service层 ,modle层 和 Dao层的功能区分

    首先这是现在最基本的分层方式,结合了SSH架构.modle层就是对应的数据库表的实体类.Dao层是使用了Hibernate连接数据库.操作数据库(增删改查).Service层:引用对应的Dao数据库操 ...

  7. java中dao层和service层的区别是什么?

    首先解释面上意思,service是业务层,dao是数据访问层.呵呵,这个问题我曾经也有过,记得以前刚学编程的时候,都是在service里直接调用dao,service里面就new一个dao类对象,调用 ...

  8. JAVA中Action层, Service层 ,modle层 和 Dao层的功能区分

    Dao层是使用了Hibernate连接数据库.操作数据库(增删改查).Service层:引用对应的Dao数据库操作,在这里可以编写自己需要的代码(比如简单的判断).Action层:引用对应的Servi ...

  9. 深入理解--SSM框架中Dao层,Mapper层,controller层,service层,model层,entity层都有什么作用

    SSM是sping+springMVC+mybatis集成的框架. MVC即model view controller. model层=entity层.存放我们的实体类,与数据库中的属性值基本保持一致 ...

随机推荐

  1. js小时分钟控件--

    直接上代码: var str = ""; document.writeln("<div id=\"_contents\" tabindex=99 ...

  2. Linux中常用操作命令

    常用指令 ls        显示文件或目录 -l           列出文件详细信息l(list) -a          列出当前目录下所有文件及目录,包括隐藏的a(all) mkdir     ...

  3. 【代码】二进制转BCD [转]

    BCD:Binary Coded Decimal 即用4位二进制编码表示1位的十进制数.   定义:BCD码这种编码形式利用了四个位元来储存一个十进制的数码,使二进制和十进制之间的转换得以快捷的进行. ...

  4. D. Game with Strings

    http://codeforces.com/contest/355/problem/D 这道题问了一下学妹,难道说哥已经老了!!! 首先题意理解上有些问题 比如说 a   b    c b   d   ...

  5. js⑥

    // 万物皆对象 var num = 123456.789;  console.log(num.toFixed(2));  console.log(num.toExponential())  cons ...

  6. (转) 如何让 UITableView 的 headerView跟随 cell一起滚动

    在我们利用 UITableView 展示我们的内容的时候,我需要在顶部放一个不同于一般的cell的 界面,这个界面比较独特. 1. 所以我就把它 作为一个section的 headerView. 也就 ...

  7. Java IO流

    File类 ·java.io.File类:文件和目录路径名的抽象表示形式,与平台无关 ·File能新建.删除.重命名文件和目录,但File不能访问文件内容本身.如果需要访问文件内容本身,则需要使用输入 ...

  8. JQuery中$.ajax()方法参数都有哪些?

    url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址. type: 要求为String类型的参数,请求方式(post或get)默认为get.注意其他http请求方法,例如put和 ...

  9. 用Python获取沪深两市上市公司股票信息,提取创近10天股价新高的、停牌的、复牌不超过一天或者新发行的股票,并存入mysql数据库

    #该脚本可以提取沪深两市上市公司股票信息,并按以下信息分类:(1)当天股价创近10个交易日新高的股票:(2)停牌的股票:(3)复牌不超过一个交易日或者新发行的股票 #将分类后的股票及其信息(股价新高. ...

  10. 细说JAVA反射

    Reflection 是 Java 程序开发语言的特征之一,它允许运行中的 Java 程序对自身进行检查,或者说“自审”,并能直接操作程序的内部属性.例如,使用它能获得 Java 类中各成员的名称并显 ...