nutz1.b.45缓存

因个人服务器小,就一个mysql数据库,网站有点多,然后那些基本是nutz开发的,所以就加了个简单的缓存。

json配置:

 

nutDao : {

type : "org.nutz.dao.impl.NutDao",

args : [{refer:"dataSource"}]

},

cache : {

type : "org.nutz.dao.cache.CacheExecExterior",

fields : {

cacheController : [{refer : 'cacheController'}],

clazzList : [["com.scxxs.auto.model.CrudUrl",100000]

,["com.xxx.xxx.model.News",100000]

,["com.xxx.xxx.model.Type",100000]],

isEnableCache : true

}

},

cacheController : {

type : "org.nutz.dao.cache.MemeoryCacheImpl",

},

daoExecutorImpl : {

type : 

"org.nutz.dao.DaoExecutorImpl",

fields : {

list : [{refer : 'cache'}]

}

}

 

dao使用:

 

dao = ioc.get(NutDao.class);

dao.setExecutor(ioc.get(DaoExecutorImpl.class));

 

相信大家都懂了吧。嘿嘿。

就实现了在本机内存中缓存数据,要加的话,实现接口即可。

以前写的那个版本太老了。不过都是从上面复制过来的代码。凑合用着。

 

 

不好意思,没仔细测试。。

DaoExecutorImpl加个方法

 

private String toExampleStatement(Object[][] mtrx, String sql) {

        StringBuilder sb = new StringBuilder();

        String[] ss = sql.split("[?]");

        int i = 0;

        if (mtrx.length > 0) {

            for (; i < mtrx[0].length; i++) {

                sb.append(ss[i]);

                Object obj = mtrx[0][i];

                if (obj != null) {

                    if (obj instanceof Blob) {

                        Blob blob = (Blob) obj;

                        obj = "Blob(" + blob.hashCode() + ")";

                    } else if (obj instanceof Clob) {

                        Clob clob = (Clob) obj;

                        obj = "Clob(" + clob.hashCode() + ")";

                    } else if (obj instanceof byte[] || obj instanceof char[]) {

                        if (Array.getLength(obj) > 10240)

                            obj = "*BigData[len=" + Array.getLength(obj) + "]";

                    } else if (obj instanceof InputStream) {

                        try {

                            obj = "*InputStream[len=" + ((InputStream) obj).available() + "]";

                        }

                        catch (IOException e) {}

                    } else if (obj instanceof Reader) {

                        obj = "*Reader@" + obj.hashCode();

                    }

                }

                sb.append(Sqls.formatFieldValue(obj));

            }

        }

        if (i < ss.length)

            sb.append(ss[i]);

 

        return sb.toString();

    }

 

然后在传入SQL哪里修改成使用本方法即可。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值