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

}

}

}

相关推荐
潜创微科技2 小时前
IT6520:USB‑C 转 MIPI 芯片方案 4K@120Hz 高清显示
c语言·开发语言
言之。3 小时前
【Python】免费的中文 AI 配音方案
开发语言·人工智能·python
天天进步20153 小时前
Python全栈项目:从零手操一个高性能 API 网关
开发语言·python
Java面试题总结3 小时前
java高频面试题(2026最新)
java·开发语言·jvm·数据库·spring·缓存
安生生申4 小时前
使用pygame实现2048
开发语言·python·pygame
hh.h.5 小时前
CANN算子开发入门:从零开始写第一个Ascend C算子
c语言·开发语言·cann·c算子
AI科技星5 小时前
全域数学·第三部·数术几何部·平行网格卷 完整专著目录(含拓扑发展史+学科定位·终稿)
c语言·开发语言·网络·量子计算·agi
SunnyDays10115 小时前
Java 读写 Excel 公式:从基础到高级的实战总结
java·开发语言·excel
wb043072015 小时前
Java 26
java·开发语言
白露与泡影5 小时前
JVM GC调优实战:从线上频繁Full GC到RT降低80%的全过程
java·开发语言·jvm