【无标题】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;

}

}

}

相关推荐
郑州光合科技余经理6 天前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
feifeigo1236 天前
matlab画图工具
开发语言·matlab
dustcell.6 天前
haproxy七层代理
java·开发语言·前端
norlan_jame6 天前
C-PHY与D-PHY差异
c语言·开发语言
多恩Stone6 天前
【C++入门扫盲1】C++ 与 Python:类型、编译器/解释器与 CPU 的关系
开发语言·c++·人工智能·python·算法·3d·aigc
QQ4022054966 天前
Python+django+vue3预制菜半成品配菜平台
开发语言·python·django
遥遥江上月6 天前
Node.js + Stagehand + Python 部署
开发语言·python·node.js
m0_531237176 天前
C语言-数组练习进阶
c语言·开发语言·算法
Railshiqian6 天前
给android源码下的模拟器添加两个后排屏的修改
android·开发语言·javascript
雪人不是菜鸡6 天前
简单工厂模式
开发语言·算法·c#