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

}

}

}

相关推荐
上单带刀不带妹22 分钟前
手写 Vue 中虚拟 DOM 到真实 DOM 的完整过程
开发语言·前端·javascript·vue.js·前端框架
-凌凌漆-1 小时前
【Qt】QStringLiteral 介绍
开发语言·qt
程序员爱钓鱼1 小时前
Go语言项目工程化 — 常见开发工具与 CI/CD 支持
开发语言·后端·golang·gin
军训猫猫头2 小时前
1.如何对多个控件进行高效的绑定 C#例子 WPF例子
开发语言·算法·c#·.net
真的想上岸啊2 小时前
学习C++、QT---18(C++ 记事本项目的stylesheet)
开发语言·c++·学习
明天好,会的2 小时前
跨平台ZeroMQ:在Rust中使用zmq库的完整指南
开发语言·后端·rust
丁劲犇3 小时前
用 Turbo Vision 2 为 Qt 6 控制台应用创建 TUI 字符 MainFrame
开发语言·c++·qt·tui·字符界面·curse
旷世奇才李先生3 小时前
Next.js 安装使用教程
开发语言·javascript·ecmascript
charlie1145141913 小时前
深入理解Qt的SetWindowsFlags函数
开发语言·c++·qt·原理分析
likeGhee4 小时前
python缓存装饰器实现方案
开发语言·python·缓存