模拟搭建Web项目的真实运行环境(六)
今天把Redis和Mongodb的操作整理一下,方便日后自己查看,废话不多说,直接进入主题。
一、Redis
1. 引用StackExchange.Redis.dll
由于ServiceStack.Redis在4.0以上已经是商业版本需要收费了,
所以在这里我选择了StackExchange.Redis应用于项目中。
首先需要获取StackExchange.Redis.dll,这里有几种方式可以得到:
① 直接下载stackexchange.redis.dll运行(推荐,简单方便)
② 去redis官网下载客户端的C#版本,然后在本地运行编译,生成stackexchange.redis.dll
(小狼几次由于网络不稳定,编译时在还原NuGet包的过程中总是不通过,导致生成的dll有问题)
③ 在 vs 里面,用nuget安装stackexchange.redis库
(通过NuGet的方式安装,框架中会多出一些可能不需要用到的库,增加项目大小)
这里我提供了一个自己上传的stackexchange.redis.dll,有需要的朋友可以下载。
百度网盘:http://pan.baidu.com/s/1qXUM39M 密码:vnrz
下载好文件加压之后在项目中引用,然后在代码中添加:
using StackExchange.Redis;
2. 创建一个Conn对象
ConnectionMultiplexer conn = ConnectionMultiplexer.Connect("192.168.1.111,password=admin");
上面的192.168.1.111是redis服务的ip地址,admin是redis服务的密码。
3. 创建一个db对象
IDatabase db = conn.GetDatabase(0);
参数0代表选择的是redis服务端的0数据库
4. 通过对象db就可以实现对redis的操作了
在下一篇附上一个小案例,简单封装了对Redis和Mongodb的操作,
有兴趣的可以下载看看。这里就不对db的方法一个一个展开介绍了。
二、Mongodb驱动
1. 从mongo官网下载C#驱动
官网地址:http://mongodb.github.io/mongo-csharp-driver/2.2/getting_started/installation/
百度网盘:http://pan.baidu.com/s/1c2v9tIS 密码:lt8m
2. 解压下载好的驱动,在项目中引用三个文件:
MongoDB.Bson.dll
MongoDB.Driver.dll
MongoDB.Driver.Core.dll
3. 在程序代码中添加:
using MongoDB.Bson;
using MongoDB.Driver;
4. 创建Client对象
IMongoClient client = new MongoClient("mongodb://192.168.1.111:27017");
5.创建Database对象
IMongoDatabase db = client.GetDatabase("db_sys");
6. 创建Collection对象
IMongoCollection<UserEntity> collection = db.GetCollection<UserEntity>("user");
7. 筛选条件
在介绍CRUD之前,先介绍筛选条件中几个重要的语法,
在这里我们把一个筛选条件(filter)作为原子来处理,
设为$a(后面小狼封装的类库中也是根据这个原理来设计)
(1)等于(Equal)
$a = key: value
*案例:
查询数据:老狼、小杨、C+、阿东、小豪、小静、老狼大傻逼
查询条件:key: '老狼'}
查询结果:老狼
(2)大于(Greater)
$a = key: {$gt: value}
*案例:
查询数据:20、21、22、23
查询条件:key: {$gt: 21}
查询结果:22、23
(3)小于(Less)
$a = key: {$lt: value}
*案例:
查询数据:20、21、22、23
查询条件:key: {$lt: 21}
查询结果:20
(4)大于等于(GreateOrEqual)
$a = key: {$gte: value}
*案例:
查询数据:20、21、22、23
查询条件:key: {$gte: 21}
查询结果:21、22、23
(5)小于等于(LessOrEqual)
$a = key: {$lte: value}
*案例:
查询数据:20、21、22、23
查询条件:key: {$lte: 21}
查询结果:20、21
(6)不等于(NotEqual)
$a = key: {$ne: value}
*案例:
查询数据:20、21、22、23
查询条件:key: {$ne: 21}
查询结果:20、22、23
(7)开区间(Between)
$a = key: {$gt: value0, <: value1}
*案例:
查询数据:20、21、22、23
查询条件:key: {$gt: 21, <: 23}
查询结果:22
(8)包含(In)
$a = key: {$in: array}
*案例:
查询数据:0、1、2、3
查询条件:key: {$in: [1,2]}
查询结果:1、2
(9)不包含(NotIn)
$a = key: {$nin: array}
*案例:
查询数据:0、1、2、3
查询条件:key: {$nin: [1,2]}
查询结果:0、3
(10)模糊查询(Like)
①必须以指定值开头:key: /^value/
②指定值前面必须有其他值:key: /.value/
③包含指定值:key: /value/
*案例:
查询数据:小狼、老狼、狼群、狼窝、灰太狼、天狼星、小杨
查询条件:
①$a = key: /^狼/
②$a = key: /.狼/
③$a = key: /狼/
查询结果:
①狼群、狼窝
②小狼、老狼、灰太狼、天狼星
③小狼、老狼、狼群、狼窝、灰太狼、天狼星
其实你可以发现,第一种和第二种的合集就是第三种
(11)逻辑与(And)
假设$a = key:value,
则$c = $a, $b
(12)逻辑或(Or)
假设$a = key:value,
则$c = $or:[{$a}, {$b}]
8. 分页排序查询
collection.Find(filter, null).Sort("{ctime: -1}").Skip((index-1) * size).Limit(size).ToList<T>();
9. 创建
UserEntity entity = new UserEntity();
collection.InsertOne(entity);
10.更新
filter:更新时的筛选条件
update:更新的内容
collection.UpdateOne(filter, update);
11. 删除
collection.DeleteOne("{_id: '00010001'}");
关于mongo驱动的CRUD的介绍告一段落,下一篇介绍一个小案例,
主要是一个用户详情表格的增删改查,主要以mongo驱动的使用为主,
其中增删改查用的是mongodb,而用户ID的自增用到了redis,
最后推荐一位前辈总结的一篇文章,写的很详细:
http://www.cnblogs.com/wuhuacong/archive/2016/01/05/5098348.html
模拟搭建Web项目的真实运行环境(六)的更多相关文章
- 模拟搭建Web项目的真实运行环境(一)
序言 最近尝试完整搭建一个Web项目的运行环境,总结一下这几个月学到的知识点. 后面的文章主要包括一下几个内容: A. 搭建一个Linux服务器,用来部署Redis.Mongo等数据存储环境: B. ...
- 模拟搭建Web项目的真实运行环境(四)
本篇介绍如何部署mongodb环境,主要分为三个部分: 第一部分 介绍如何在ubuntu下安装mongodb, 第二部分 介绍如何在windows下安装使用MongoChef客户端, 第三部分 介绍在 ...
- 模拟搭建Web项目的真实运行环境(七)
下面这个是mongo驱动的小案例,里面也有涉及到一点redis的操作 https://github.com/SuperRocky/MyMongoDriver 接下来通过几张图片主要介绍一下每个文件的具 ...
- 模拟搭建Web项目的真实运行环境(五)
一.开启IIS功能 刚安装完的server2008是没有默认开启IIS功能,在这里简单介绍一下如何开启IIS. 步骤: 1. 打开控制面板,选中[程序] 2. 在[程序和功能]下面,选择[打开或关闭w ...
- 模拟搭建Web项目的真实运行环境(三)
一.解决Redis出现的RDB权限问题 当你在安装redis的时候,如果是使用超级用户root安装, 开启redis服务的时候没有用超级用户去开启, 在用客户端登录redis,然后使用shutdown ...
- 模拟搭建Web项目的真实运行环境(二)
上一节已经介绍了如何在虚拟机中部署测试环境,接下来将介绍怎么在ubuntu下部署redis. 一.在ubuntu安装Xrdp + Vnc 为了在以后可以通过windows系统来远程操作ubuntu ...
- 【maven】 在 MyEcplise上使用maven搭建Web项目
二.在My Ecplise上使用Maven搭建Web项目 1.新建一个maven项目 2.create一个简单的骨架 3.就像在ecplise中一样设置项目的以下配置 4.新创建的项目结构如下 ...
- Spring-Boot快速搭建web项目详细总结
最近在学习Spring Boot 相关的技术,刚接触就有种相见恨晚的感觉,因为用spring boot进行项目的搭建是在太方便了,我们往往只需要很简单的几步,便可完成一个spring MVC项目的搭建 ...
- 如何使用maven搭建web项目
博客园注册了有二十多天了,还没有写过博客,今天就发一篇,也便于后面查找笔记. 我个人已经做了几年的java web开发了,由于所在的公司是业务型公司,用的都是一些老旧的稳定技术,很少接触到稍微新点的内 ...
随机推荐
- 批量从jar包中提取pom.xml
将非maven项目转换为maven项目,首要第一步就是提取原工程依赖jar里的pom.xml,拼成<dependency>节点 import java.io.File; import ja ...
- RabbitMQ 集群之镜像同步
mirrored 在上个博文中讲到了如果做集群,那么集群是成功了,但是queue是如何存放的呢?消息又是怎么同步呢. 默认的,也就是什么也不配置,直接在某个节点中添加一个queue,那么它仅仅是属于这 ...
- ES6入门笔记
ES6入门笔记 02 Let&Const.md 增加了块级作用域. 常量 避免了变量提升 03 变量的解构赋值.md var [a, b, c] = [1, 2, 3]; var [[a,d] ...
- Docker命令详解
Docker命令详解 最近学习Docker,将docker所有命令实验了一番,特整理如下: # docker --help Usage: docker [OPTIONS] COMMAND [arg ...
- coreseek 安装及使用方法详解
coreseek 安装及使用 一般站点都需要搜索功能,如果是php+mysql站点,建议选择coreseek,如果是java站点建议使用lucene,coreseek 是一款很好的中文全文检索/搜索软 ...
- mysql-proxy 读写分离
mysql-proxy 读写分离 主从复制 MySQL Replication可以将master的数据复制分布到多个slave上,然后利用slave来分担master的读压力. 读写分离 MySQL- ...
- 【01-06】JPA 全局单一主键
建一张主键表 @Override public boolean equals(Object o) { return (o == this || (o instanceof AbstractEntity ...
- yum 操作复习
RPM与YUM是配合使用的. rpm负责从网站或指定的文件路径,获取到rpm软件包.也就是说你要安装什么服务或软件,就要先找到rpm包,下载下来.也就是通常说的配置yum源. 啥是yum源.你下载下的 ...
- REDHAT一总复习1 cups 打印服务配置
停止cups服务 $ sudo systemctl stop cups $ sudo systemctl status cups 配置cups服务,使其不在系统启动时启动 $ sudo systemc ...
- JS事件的三种方式
1.直接在元素上绑定回调函数 <button id="btn" onclick="clickBtn()">click me</button&g ...