缓存

一、通过数据库的sysdate字段

public class CacheData
{

/// <summary>
/// 字典集合
/// </summary>
private static Dictionary<string, DataTable> dicStuData = new Dictionary<string, DataTable>()// <summary>

/// 根据班级查找班级学生信息
/// </summary>
/// <returns></returns>
public static DataTable GetStuInfoByName(string name)
{
DataTable dt=null;
//次日清空
if (dicStuData .TryGetValue(name, out dt)&&dt.Rows.Count>0)
{
DateTime cacheTime = Convert.ToDateTime(dt.Rows[0]["sysdate"]);
//缓存一天
if (cacheTime.Date != DateTime.Now.Date)
{
dicStuData [name] = null;
}
}

if (dt == null|| dt.Rows.Count == 0)
{
//查询学生信息
string sql = @"select  distinct  stuname,stuNo, address , sysdate from classInfo
where classname ='{0}'";
try
{

//查询数据库
dt=dicStuData [name] = DBContext.GetDataTable(sql);
}
catch (Exception ex)
{

//记录错误日志
Log.Error("根据班级名:["+name+"],查询学生信息异常:", ex);
}
}
return dt;
}

}

转载于:https://www.cnblogs.com/LeiYang5237/p/7500324.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值