`
收藏列表
标题 标签 来源
java缓存学习 java缓存技术学习
package com.citics.crm.customerwidget.utils;  
  
/** 
 * <p>Description: 缓存DTO</p> 
 * @version 1.0 
 */  
public class Cache {  
        private String key;//缓存ID  
        private Object value;//缓存数据  
        private long timeOut;//更新时间  
        private boolean expired; //是否终止  
        public Cache() {  
                super();  
        }  
  
        public Cache(String key, Object value, long timeOut, boolean expired) {  
                this.key = key;  
                this.value = value;  
                this.timeOut = timeOut;  
                this.expired = expired;  
        }  
  
        public String getKey() {  
                return key;  
        }  
  
        public long getTimeOut() {  
                return timeOut;  
        }  
  
        public Object getValue() {  
                return value;  
        }  
  
        public void setKey(String string) {  
                key = string;  
        }  
  
        public void setTimeOut(long l) {  
                timeOut = l;  
        }  
  
        public void setValue(Object object) {  
                value = object;  
        }  
  
        public boolean isExpired() {  
                return expired;  
        }  
  
        public void setExpired(boolean b) {  
                expired = b;  
        }  
}  
  



package com.citics.crm.customerwidget.utils;  
  
import java.util.*;  
  
/** 
 * <p>Title: </p> 
 * 
 * <p>Description: 管理缓存</p> 
 * Deep blue 2008-11-28 think 
 * 可扩展的功能:当chche到内存溢出时必须清除掉最早期的一些缓存对象,这就要求对每个缓存对象保存创建时间 
 * @version 1.0 
 */  
public class CacheUtil {  
    private static HashMap cacheMap = new HashMap();  
  
    //单实例构造方法  
    private CacheUtil() {  
        super();  
    }  
    //获取布尔值的缓存  
    public static boolean getSimpleFlag(String key){  
        try{  
            return (Boolean) cacheMap.get(key);  
        }catch(NullPointerException e){  
            return false;  
        }  
    }  
    public static long getServerStartdt(String key){  
        try {  
            return (Long)cacheMap.get(key);  
        } catch (Exception ex) {  
            return 0;  
        }  
    }  
    //设置布尔值的缓存  
    public synchronized static boolean setSimpleFlag(String key,boolean flag){  
        if (flag && getSimpleFlag(key)) {//假如为真不允许被覆盖  
            return false;  
        }else{  
            cacheMap.put(key, flag);  
            return true;  
        }  
    }  
    public synchronized static boolean setSimpleFlag(String key,long serverbegrundt){  
        if (cacheMap.get(key) == null) {  
            cacheMap.put(key,serverbegrundt);  
            return true;  
        }else{  
            return false;  
        }  
    }  
  
  
    //得到缓存。同步静态方法  
    private synchronized static Cache getCache(String key) {  
        return (Cache) cacheMap.get(key);  
    }  
  
    //判断是否存在一个缓存  
    private synchronized static boolean hasCache(String key) {  
        return cacheMap.containsKey(key);  
    }  
  
    //清除所有缓存  
    public synchronized static void clearAll() {  
        cacheMap.clear();  
    }  
  
    //清除某一类特定缓存,通过遍历HASHMAP下的所有对象,来判断它的KEY与传入的TYPE是否匹配  
    public synchronized static void clearAll(String type) {  
        Iterator i = cacheMap.entrySet().iterator();  
        String key;  
        ArrayList<String> arr = new ArrayList<String>();  
        try {  
            while (i.hasNext()) {  
                java.util.Map.Entry entry = (java.util.Map.Entry) i.next();  
                key = (String) entry.getKey();  
                if (key.startsWith(type)) { //如果匹配则删除掉  
                    arr.add(key);  
                }  
            }  
            for (int k = 0; k < arr.size(); k++) {  
                clearOnly(arr.get(k));  
            }  
        } catch (Exception ex) {  
            ex.printStackTrace();  
        }  
    }  
  
    //清除指定的缓存  
    public synchronized static void clearOnly(String key) {  
        cacheMap.remove(key);  
    }  
  
    //载入缓存  
    public synchronized static void putCache(String key, Cache obj) {  
        cacheMap.put(key, obj);  
    }  
  
    //获取缓存信息  
    public static Cache getCacheInfo(String key) {  
  
        if (hasCache(key)) {  
            Cache cache = getCache(key);  
            if (cacheExpired(cache)) { //调用判断是否终止方法  
                cache.setExpired(true);  
            }  
            return cache;  
        }else  
            return null;  
    }  
  
    //载入缓存信息  
    public static void putCacheInfo(String key, Cache obj, long dt,boolean expired) {  
        Cache cache = new Cache();  
        cache.setKey(key);  
        cache.setTimeOut(dt + System.currentTimeMillis()); //设置多久后更新缓存  
        cache.setValue(obj);  
        cache.setExpired(expired); //缓存默认载入时,终止状态为FALSE  
        cacheMap.put(key, cache);  
    }  
    //重写载入缓存信息方法  
    public static void putCacheInfo(String key,Cache obj,long dt){  
        Cache cache = new Cache();  
        cache.setKey(key);  
        cache.setTimeOut(dt+System.currentTimeMillis());  
        cache.setValue(obj);  
        cache.setExpired(false);  
        cacheMap.put(key,cache);  
    }  
  
    //判断缓存是否终止  
    public static boolean cacheExpired(Cache cache) {  
        if (null == cache) { //传入的缓存不存在  
            return false;  
        }  
        long nowDt = System.currentTimeMillis(); //系统当前的毫秒数  
        long cacheDt = cache.getTimeOut(); //缓存内的过期毫秒数  
        if (cacheDt <= 0||cacheDt>nowDt) { //过期时间小于等于零时,或者过期时间大于当前时间时,则为FALSE  
            return false;  
        } else { //大于过期时间 即过期  
            return true;  
        }  
    }  
  
    //获取缓存中的大小  
    public static int getCacheSize() {  
        return cacheMap.size();  
    }  
  
    //获取指定的类型的大小  
    public static int getCacheSize(String type) {  
        int k = 0;  
        Iterator i = cacheMap.entrySet().iterator();  
        String key;  
        try {  
            while (i.hasNext()) {  
                java.util.Map.Entry entry = (java.util.Map.Entry) i.next();  
                key = (String) entry.getKey();  
                if (key.indexOf(type) != -1) { //如果匹配则删除掉  
                    k++;  
                }  
            }  
        } catch (Exception ex) {  
            ex.printStackTrace();  
        }  
  
        return k;  
    }  
  
    //获取缓存对象中的所有键值名称  
    public static ArrayList<String> getCacheAllkey() {  
        ArrayList a = new ArrayList();  
        try {  
            Iterator i = cacheMap.entrySet().iterator();  
            while (i.hasNext()) {  
                java.util.Map.Entry entry = (java.util.Map.Entry) i.next();  
                a.add((String) entry.getKey());  
            }  
        } catch (Exception ex) {} finally {  
            return a;  
        }  
    }  
  
    //获取缓存对象中指定类型 的键值名称  
    public static ArrayList<String> getCacheListkey(String type) {  
        ArrayList a = new ArrayList();  
        String key;  
        try {  
            Iterator i = cacheMap.entrySet().iterator();  
            while (i.hasNext()) {  
                java.util.Map.Entry entry = (java.util.Map.Entry) i.next();  
                key = (String) entry.getKey();  
                if (key.indexOf(type) != -1) {  
                    a.add(key);  
                }  
            }  
        } catch (Exception ex) {} finally {  
            return a;  
        }  
    }  
  
}  
  
  

mysql数据按时间来查询 mysql查询今天、昨天、7天、近30天、本月、上一月 数据
今天

select * from 表名 where to_days(时间字段名) = to_days(now());

昨天

SELECT * FROM 表名 WHERE TO_DAYS( NOW( ) ) - TO_DAYS( 时间字段名) <= 1

7天

SELECT * FROM 表名 where DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(时间字段名)

近30天

SELECT * FROM 表名 where DATE_SUB(CURDATE(), INTERVAL 30 DAY) <= date(时间字段名)

本月

SELECT * FROM 表名 WHERE DATE_FORMAT( 时间字段名, '%Y%m' ) = DATE_FORMAT( CURDATE( ) , '%Y%m' )

上一月

SELECT * FROM 表名 WHERE PERIOD_DIFF( date_format( now( ) , '%Y%m' ) , date_format( 时间字段名, '%Y%m' ) ) =1


#查询本季度数据
select * from `ht_invoice_information` where QUARTER(create_date)=QUARTER(now());
#查询上季度数据
select * from `ht_invoice_information` where QUARTER(create_date)=QUARTER(DATE_SUB(now(),interval 1 QUARTER));
#查询本年数据
select * from `ht_invoice_information` where YEAR(create_date)=YEAR(NOW());
#查询上年数据
select * from `ht_invoice_information` where year(create_date)=year(date_sub(now(),interval 1 year));



查询当前这周的数据 
SELECT name,submittime FROM enterprise WHERE YEARWEEK(date_format(submittime,'%Y-%m-%d')) = YEARWEEK(now());

查询上周的数据
SELECT name,submittime FROM enterprise WHERE YEARWEEK(date_format(submittime,'%Y-%m-%d')) = YEARWEEK(now())-1;

查询当前月份的数据
select name,submittime from enterprise   where date_format(submittime,'%Y-%m')=date_format(now(),'%Y-%m')

查询距离当前现在6个月的数据
select name,submittime from enterprise where submittime between date_sub(now(),interval 6 month) and now();

查询上个月的数据
select name,submittime from enterprise   where date_format(submittime,'%Y-%m')=date_format(DATE_SUB(curdate(), INTERVAL 1 MONTH),'%Y-%m')

select * from ` user ` where DATE_FORMAT(pudate, ' %Y%m ' ) = DATE_FORMAT(CURDATE(), ' %Y%m ' ) ;

select * from user where WEEKOFYEAR(FROM_UNIXTIME(pudate,'%y-%m-%d')) = WEEKOFYEAR(now())

select * 
from user 
where MONTH (FROM_UNIXTIME(pudate, ' %y-%m-%d ' )) = MONTH (now())

select * 
from [ user ] 
where YEAR (FROM_UNIXTIME(pudate, ' %y-%m-%d ' )) = YEAR (now())
and MONTH (FROM_UNIXTIME(pudate, ' %y-%m-%d ' )) = MONTH (now())

select * 
from [ user ] 
where pudate between 上月最后一天
and 下月第一天

where   date(regdate)   =   curdate();

select   *   from   test   where   year(regdate)=year(now())   and   month(regdate)=month(now())   and   day(regdate)=day(now())

SELECT date( c_instime ) ,curdate( )
FROM `t_score`
WHERE 1
LIMIT 0 , 30
Global site tag (gtag.js) - Google Analytics