【无标题】c# WEBAPI 读写表到Redis

//c# WEBAPI 读写表到Redis

using System;

using System.Collections.Generic;

using System.Linq;

using System.Net;

using System.Net.Http;

using System.Web.Http;

using Newtonsoft.Json;

using StackExchange.Redis;

using System.Data;

using System.Web;

namespace Manage002.web.Controllers

{

RoutePrefix("api/Manage002ReportRedis")

public class Manage002ReportRedisController : ApiController

{

//ConnectionMultiplexer _conn = RedisConnectionHelp.Instance;//初始化

public_org_rpt por = new public_org_rpt();

public_top_rpt ptr = new public_top_rpt();

HttpGet

Route("getGoodtag")

/// <summary>

/// 从缓存中读取erp_goodtag表

/// </summary>

/// <param name="orgid">机构ID</param>

/// <returns></returns>

public DataSet getGoodtag(string orgid)

{

ConnectionMultiplexer _conn = ConnectionMultiplexer.Connect("localhost");

DataSet dsGoodtag = new DataSet();

string sqlGoodtag = @"select id,tagType,tagName,taglevel,parentid,parentlist FROM erp_goodtag ";// where orgid=" + orgid;

if (_conn != null)//开了redis

{

//根据传入的orgid读取Redis中的值

var database = _conn.GetDatabase(0);

string res = database.StringGet(orgid + "_dsGoodtag");

//判断Redis中有没有对应的值

if (string.IsNullOrEmpty(res))

{

//读取数据库

dsGoodtag = ptr.GetList(sqlGoodtag);

DataRow[] drow = null;

//根据传入的ID筛选

if (string.IsNullOrEmpty(orgid))

{

drow = dsGoodtag.Tables[0].Select();

}

else

{

drow = dsGoodtag.Tables[0].Select(" id='" + orgid + "' ");

}

//将筛选出来的记录用表结构保存,方便进行后面的序列化和反序列化

foreach (DataRow row in drow)

{

DataTable dt_sel = dsGoodtag.Tables[0].Clone();

DataRow newRow = dt_sel.NewRow();

newRow.ItemArray = row.ItemArray;

dt_sel.Rows.Add(newRow);

//对结果表进行序列化

string jsonString = JsonConvert.SerializeObject(dt_sel, Formatting.None);

//将序列化的数据保存到Redis

database.StringSet(row["id"].ToString() + "_dsGoodtag", jsonString);

}

}

else

{

//Redis中有数据时直接对数据进行反序列化

DataTable dtGoodtag = JsonConvert.DeserializeObject<DataTable>(res);

dsGoodtag.Tables.Add(dtGoodtag);

}

}

else//直接从数据库里取

{

dsGoodtag = ptr.GetList(sqlGoodtag);

}

return dsGoodtag;

}

}

}

相关推荐
她说彩礼65万8 分钟前
C# 中的锁
开发语言·c#
2302_809798328 分钟前
【JavaWeb】JDBC
java·开发语言·servlet
繁依Fanyi27 分钟前
ImgShrink:摄影暗房里的在线图片压缩工具开发记
开发语言·前端·codebuddy首席试玩官
卓律涤32 分钟前
【找工作系列①】【大四毕业】【复习】巩固JavaScript,了解ES6。
开发语言·前端·javascript·笔记·程序人生·职场和发展·es6
xqlily44 分钟前
MATLAB安装常见问题解决方案
开发语言·matlab
achene_ql1 小时前
基于QT和FFmpeg实现自己的视频播放器FFMediaPlayer(一)——项目总览
开发语言·qt·ffmpeg
MeyrlNotFound1 小时前
(二十一)Java集合框架源码深度解析
java·开发语言
TNTLWT1 小时前
Qt功能区:Ribbon使用
开发语言·qt·ribbon
Ronin3051 小时前
【C++】18.二叉搜索树
开发语言·数据结构·c++
Susea&1 小时前
初始C++:类和对象(中)
c语言·开发语言·c++