定時執行更新Redis緩存操做sql
protected void Application_Start(object sender, EventArgs e) { Timer timer = new Timer(); timer.Enabled = true; timer.Interval = 3600000; //執行間隔時間,單位爲毫秒; 這裏實際間隔爲1小時 timer.Start(); timer.Elapsed += new System.Timers.ElapsedEventHandler(OrgCacheInterval); } /// <summary> /// 定時檢測組織機構緩存是否須要更新 /// </summary> /// <param name="source"></param> /// <param name="e"></param> public void OrgCacheInterval(object source, ElapsedEventArgs e) { SystemService ser = new SystemService(); ser.OrgCacheInterval(); }
/// <summary> /// 組織機構緩存定時更新 /// </summary> public void OrgCacheInterval() { //不存在組織機構緩存或者時間戳時,更新 if (!RedisCacheHelper.Exists("OrgList") || !RedisCacheHelper.Exists("OrgList:Time")) { UpdateAllOrgCache(); } //存在時間戳時判斷時間是否一致,不一致時更新 else { //緩存時間戳 string cacheTime = RedisCacheHelper.Get<string>("OrgList:Time"); //數據庫更新緩存時間 string modifyTime = OrgDb.GetKeyLastModifyTime("OrgList", ""); //時間戳標記不一致時更新 if (cacheTime != modifyTime) { UpdateAllOrgCache(); } } }
/// <summary> /// 獲取鍵值更新時間 /// </summary> /// <param name="db_key"></param> /// <param name="lang_type"></param> /// <returns></returns> public string GetKeyLastModifyTime(string db_key, string lang_type) { string time = string.Empty; try { string sql = string.Format(@"select * from sys_dbcache_time t where 1=1 and t.db_key='{0}' ", db_key); if (!string.IsNullOrEmpty(lang_type)) { sql += string.Format(@" and t.lang_type='{0}' ", lang_type); } DataTable dt = OdpOracleHelper.Query(sql).Tables[0]; if (dt != null && dt.Rows.Count > 0) { time = Convert.ToDateTime(dt.Rows[0]["op_modify_time"]).ToString("yyyy-MM-dd HH:mm:ss"); } else { string _time = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"); string insertSql = string.Format(@"insert into sys_dbcache_time(db_key,lang_type,op_modify_time)
values('{0}','{1}',to_date('{2}','yyyy-MM-dd HH24:MI:SS'))", db_key, lang_type, _time); OdpOracleHelper.ExecuteSql(insertSql); time = _time; } } catch (Exception ex) { throw ex; } return time; }