基于.net ,使用几种常见的NoSQL数据库

基于.net ,使用几种常见的NoSQL数据库[toc] "示例完整源码地址" 2020年1月10日 10:10:10 shanzm 0 .net中的缓存对象 MemoryCache对象 HttpContext.Cache (

基于.net ,使用几种常见的NoSQL数据库


0 .net中的缓存对象

  • MemoryCache对象

  • HttpContext.Cache (Asp.net)对象

示例:(详见:001MemoryCache

//MemoryCache是存入到程序进程的内存中的,程序重启之后就没了
//添加引用:System.Runtime.Caching
//新建一个缓存对象,使用默认的缓存对象
MemoryCache memCache = MemoryCache.Default;
//缓存以键值对的形式存储,缓存的生命期是10s
memCache.Add("name", "shanzm", DateTimeOffset.Now.AddSeconds(10));

代码100分


1.MemCached

示例:(详见:002MemCachedDemo

代码100分//创建配置对象
MemcachedClientConfiguration memConfig = new MemcachedClientConfiguration();
memConfig.AddServer("127.0.0.1:11211");

//创建MemcachedClient对象
using (MemcachedClient memClient = new MemcachedClient(memConfig))
{
    //写入MemCached中
    memClient.Store(Enyim.Caching.Memcached.StoreMode.Set, "Name", "shanzm");
    memClient.Store(Enyim.Caching.Memcached.StoreMode.Set, "Age", "100");

    //读取数据
    string name = memClient.Get<string>("Name");
    if (name == null)
    {
        Console.WriteLine("无缓存");
    }
    else
    {
        Console.WriteLine(name);
    }

    //删除数据
    Console.WriteLine(memClient.Get<string>("Age"));
    memClient.Remove("Age");
    if (null == memClient.Get<string>("Age"))
    {
        Console.WriteLine("已经将Key为Age的数据从MemCached服务器中清除");

    }
    Console.ReadKey();
}

2.Redis

示例:(详见:004RedisDemo)

//注意此处我们使用异步方法
using (ConnectionMultiplexer conn = await ConnectionMultiplexer.ConnectAsync("127.0.0.1:6379"))
{
    //默认是0号数据库,若是其他数据库,如3号数据库,conn.GetDatabase(3)
    IDatabase db = conn.GetDatabase();

    //写入数据
    await db.StringSetAsync("Name", "张三", TimeSpan.FromSeconds(10));

    //批量写入(使用Redis中Batch对象 见013Redis的批量操作)
    KeyValuePair<RedisKey, RedisValue>[] kvs = new KeyValuePair<RedisKey, RedisValue>[3];

    kvs[0] = new KeyValuePair<RedisKey, RedisValue>("A", "a");
    kvs[1] = new KeyValuePair<RedisKey, RedisValue>("B", "b");
    kvs[2] = new KeyValuePair<RedisKey, RedisValue>("C", "c");
    await db.StringSetAsync(kvs);

    //读取数据(查询不到数据返回为null)
    string name = await db.StringGetAsync("Name");
    string A = await db.StringGetAsync("A");

    //删除数据
    db.KeyDelete("A");

    //判断是否存在某条数据
    if (!db.KeyExists("A"))
    {
        MessageBox.Show("已删除Key值为‘A’的数据");
    }

    //对已经存储的数据设置过期时间
    db.KeyExpire("B", TimeSpan.FromSeconds(10));
}

3.MongoDB

  • 安装MongoDB(官方地址

  • 安装MongoDB GUI客户端:Robo3T

  • NuGet:PM>Install-Package MongoDB.Driver -Version 2.5.0
    (注意默认安装最新版本可能会报错
    亲测2.5.0版本和 .net Framework版本是4.6.1完美支持)

  • MongoDB中的完整的增删改查,见:017MongoDB中的CURD

示例:(详见:016MongoDBDemo)

代码100分//连接MongoDB服务,创建对象
MongoClient client = new MongoClient("mongodb://127.0.0.1:27017");
//获取名为:TestDb1的数据库,若是没有则创建!
IMongoDatabase db = client.GetDatabase("TestDb1");
//获取名为名为Personsde表(collection可以理解为表)若是没有则创建!
IMongoCollection<Person> persons = db.GetCollection<Person>("Persons");


Person p1 = new Person() { Id = 0001, Name = "shanzm", Age = 25 };
Person p2 = new Person() { Id = 002, Name = "shanzm" };//MongoDB会对Age默认填充为0

persons.InsertOne(p1);
persons.InsertOne(p2);

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/10252.html

(0)
上一篇 2023-01-22
下一篇 2023-01-22

相关推荐

  • Python实战:使用findstr函数快速查找字符串

    Python实战:使用findstr函数快速查找字符串在我们的日常开发和维护中,常常需要查找某个关键字在代码文件或者文本文件中出现的位置。Python的字符串函数库提供了丰富的函数可以用于字符串的处理和查找,其中findstr函数被广泛使用,它可以帮助我们在字符串中快速定位指定的子字符串,并返回位置信息以便于进行进一步的处理。

    2024-01-12
    104
  • 使用原生的python的简单介绍

    使用原生的python的简单介绍支持常见的主流平台,如AIX、HPUX、Solaris、Linux、Windows等,除Windows外常见的Unix、Linux平台均带有原生的Python,但版本一般较低。

    2023-11-25
    148
  • 原生php pdo几个处理「建议收藏」

    原生php pdo几个处理「建议收藏」闲来无事,便记录几个最近遇到的Pdo细节问题,平常都是用orm的。 长连接 在历史的Mysql驱动中,都是使用connect和pconnect来区分长短连接,到了pdo之后,改成了参数。 PDO::…

    2022-12-22
    131
  • mysql系列(十)——Mysql常见的工具

    mysql系列(十)——Mysql常见的工具一、压力测试工具——【mysqlslap】 二、 数据库表物理结构修改工具——【pt-online-schema-change】 三、慢查询分析工具—— 【mysqldumpslow】 四、慢查询分…

    2023-03-20
    153
  • HDFS/HBase技术报告·分布式数据库设计架构的全面解析「终于解决」

    HDFS/HBase技术报告·分布式数据库设计架构的全面解析「终于解决」Hadoop生态的分布式数据库 1、什么是分布式数据库? 从狭义的理解就是分布式关系型数据库,主要特指目前热门的NewSQL。 从广义的理解,分库分表的传统关系型数据库,传统关系型数据库集群,关系型数

    2023-04-14
    144
  • TcaplusDB君的小知识之TcaplusDB的高可用性和数据安全性介绍

    TcaplusDB君的小知识之TcaplusDB的高可用性和数据安全性介绍随着信息化的发展,数据库已经是企业正常运营必不可少的工具,企业的所有数据都存储在数据库上,因此可以说数据库的可靠与否关系着企业的生死存亡。 因此,数据的保护和备份是数据库业务的重中之重,系统的可用性…

    2023-04-10
    163
  • 范式通俗理解:1NF、2NF、3NF和BNCF

    范式通俗理解:1NF、2NF、3NF和BNCFhttps://blog.csdn.net/wyh7280/article/details/83350722 范式通俗理解:1NF、2NF、3NF和BNCF原创hongiii 最后发布于2018-10

    2023-01-31
    156
  • 使用Python编写更快的算法

    使用Python编写更快的算法Python是一种强大而简单易学的编程语言。对于许多类别的问题,Python是一种很好的解决方案。然而,以牺牲效率为代价的语言也常常会发生在Python上,因为它往往比编译语言慢得多。在这篇文章中,我们将讨论如何使用Python编写更快的算法,同时保持代码简洁易懂。

    2024-01-03
    106

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注