当前位置: 首页 > news >正文

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


    }
}
 

http://www.lryc.cn/news/387393.html

相关文章:

  • 【剑指Offer系列】53-0到n中缺失的数字(index)
  • docker compose部署zabbix7.0官方方法快速搭建
  • 分库分表之后如何设计主键ID(分布式ID)?
  • 秋招突击——6/28、6.29——复习{数位DP——度的数量}——新作{}
  • Spring Boot中使用Thymeleaf进行页面渲染
  • 恢复策略(下)-事务故障后的数据库恢复、系统故障后的数据库恢复(检查点技术)、介质故障后的数据库恢复
  • 如何知道docker谁占用的显卡的显存?
  • wps linux node.js 加载项开发,和离线部署方案
  • 红队内网攻防渗透:内网渗透之内网对抗:横向移动篇Kerberos委派安全非约束系约束系RBCD资源系Spooler利用
  • nginx上传文件限制
  • 76. 最小覆盖子串(困难)
  • K8S 集群节点扩容
  • AI大模型技术在音乐创造的应用前景
  • Linux多进程和多线程(一)-进程的概念和创建
  • 熊猫烧香是什么?
  • 使用Vue3和Tailwind CSS快速搭建响应式布局
  • J019_选择排序
  • 【linux】vim的使用
  • 【工具测评】ONLYOFFICE8.1版本桌面编辑器测评:好用!
  • 核方法总结(四)——高斯过程回归学习笔记
  • 【Python3的内置函数和使用方法】
  • 递推算法计算信号特征
  • spring-boot-configuration-processor注释处理器
  • Python和MATLAB粘性力接触力动态模型半隐式欧拉算法
  • webstorm无法识别tsconfig.json引用项目配置文件中的路径别名
  • qiankun微前端:qiankun+vite+vue3+ts(未完待续..)
  • 001:开源交易系统开发实战开篇
  • Pytorch实战(一):LeNet神经网络
  • RabbitMq的基础及springAmqp的使用
  • uniapp uniCloud云开发