Top ↑
无匹配结果,请重新输入
Dao拦截器
Jul 10, 2017 10:38:44 AM
作者: wendal

为啥要实现Dao拦截器

  • DaoRunner和DaoExecutor的定制成本较高,拦截器让NutDao更容易定制.
  • 之前的设计没法很好的实现事务分离(DaoSupport和NutDaoRunner均有事务相关的代码)

内置的拦截器实现

  • log -- 输出SQL语句到日志,这是NutDao默认情况下唯一启用的拦截器
  • time -- 打印sql执行耗时

如何自定义

需要实现的接口

public interface DaoInterceptor {
    void filter(DaoInterceptorChain chain) throws DaoException;
}
// DaoInterceptorChain 包含当前执行的全部信息,如Connection,DaoStatment等等

示例实现

public class MyDaoInterceptor implements DaoInterceptor {
    public void filter(DaoInterceptorChain chain) throws DaoException {
        DaoStatement st = chain.getDaoStatement();
        if (st instanceof NutPojo) {
            // 如果是dao.insert(user)之类的操作,会进入这个分支
        } else if (st instanceof NutSql) {
            // 如果是自定义SQL,会进入这个分支
        }
        chain.doChain();//继续下一个拦截器执行
    }
}

在ioc中的配置,以dao.js为例

var ioc = {
        dao : {
            type : "org.nutz.dao.impl.NutDao",
            args : [{refer:"dataSource"}],
            fields : {
                interceptors : [
                            "log", // 默认的日志还需要的
                            "time", // 加个时间又如何呢?
                            "net.demo.MyDaoInterceptor", // 加入自己的,才合适
                            {refer:"superI"} // 引用另外一个bean作为拦截器
                            ]
            }
        }
}

本页面的文字允许在知识共享 署名-相同方式共享 3.0协议GNU自由文档许可证下修改和再使用。