基础拾遗-----mongoDB操作
基础拾遗
前言
nosq互联网中运用极广的技术,mongo应该算是必不可少的技术之一,虽说我在项目中redis用的较多,mongo在项目中算是用的比较少的技术,但是也在以前的技术总监的要求下了解了一些先关的东西,但不够深入,只是简单的了解了一下,对它只是处于了解使用阶段,以下简单的把自己了解的东西介绍一下,其中类库是我们总监的编写了,再次仅作为记入。(虽说已经从原总监那离开好久,但是整体说来他的技术依然还是我见过最全面,最厉害的。在这页感谢那段时间对我的教导吧。)
1.mongoDB的配置:
1.1增加MongoDB密码
1.1.1、给mongo添加权限认证
1、启动mongod, 非认证状态启动
2、登录mongo
3.
>use admin
>db.createUser({user:",roles:[{role:"userAdminAnyDatabase",db:"admin"}]})
/**不执行下面三句的话,只能mongo命令行可以访问,第三方程序无法访问
>var schema = db.system.version.findOne({"_id" : "authSchema"})
>schema.currentVersion =
>db.system.version.save(schema)
>use 你的DB名 --> 这点很重要
>db.createUser({user:",roles:[{role:"readWrite",db:"你的DB名"}]})
4、修改mongo配置文件
#auth = true ----> 去掉#即可
完成。
1.1.2。新建DB或者给已有DB添加用户
1、可以用admin登录
>mongo localhost\admin -u admin -p 123456
与上面相同
>var schema = db.system.version.findOne({"_id" : "authSchema"})
>schema.currentVersion = 3
>db.system.version.save(schema)
>use 你的DB
>db.createUser({user:"user",pwd:"123456",roles:[{role:"readWrite",db:"你的DB名"}]})
1.1.3.登录查看
>mongo登录
>use admin
>db.auth("user","123456")
>use 你的DB名
>show collections;
1.2.webconfig的配置
<connectionStrings> <add name="TestDBContext" connectionString="mongodb://user:pwd@ip:27017/TestMongo"/> </connectionStrings>
其中TestMongo为mongo文件,不用考虑路径什么的,安装mongo的时候已经在服务里映射到。1.3gloal实例化
MongoDBRepository.RegisterMongoDBContext(new TestDBContext());
MongoDBRepository.RegisterMongoIndex();
MongoDBRepository.RegisterMongoIndex();是用来实例化索引的,需要添加所以的的字段需要表示一下特性:
[AttributeUsage(AttributeTargets.Property | AttributeTargets.Field)]
public class BsonIndexAttribute : Attribute
{
}
操作如下:
public class Student : Entity
{
[BsonIndex]
public string Name { get; set; }
public int Age { get; set; }
}
2.代码操作:
2.1。基本操作
public class Student : Entity
{
public string Name { get; set; }
public int Age { get; set; }
}
public class TestDBContext : MongoDBContext
{
//TestDBContext即配置文件中的节点的名称
public TestDBContext() : base("TestDBContext") { }
public override void OnRegisterModel(ITypeRegistration registration)
{
registration.RegisterType<Student>();//在上下文中注册可用的实例
}
}
public void Setup()
{
MongoDBRepository.RegisterMongoDBContext(new TestDBContext());//注册上下文
Student student = new Student();
student.Name = "wyl";
student.Age = 26;
student.Save();//保存当前实例到数据库
student.Remove()//删除当前实例
}
TestDBContext为上面的配置文件。
以下利用lamdam表达式的操作,自行领会
//获取实例
var stud = Entity.Get<Student>(student.Id);
var stud = Entity.Get<Student>(s=>s.Age=="hyf");<br>
//分页查询
var querable = Entity.Select<Student>(s => s.Age >= 19 && s.Age <= 22, s => s.Age, 1, 2, out pageCount, out allCount).ToList();
//批量删除
Entity.RemoveAll<Student>(e => e.Name == "hyf");
//批量保存
Entity.Save(new List<Student>() {
new Student{ Name="hyf", Age=33 },
new Student{ Name="zhc", Age=30 }
});
2.2.Mongo之DBRef关联操作
MongoDB对一对一,一对多,多对多关系的维护,官方文件建议用文档嵌套的方式。
public class Student : Entity
{
public string Name { get; set; }
public int Age { get; set; }
}
public class Teacher : Entity
{
public string Name { get; set; }
public int Age { get; set; }
}
public class Master: RefEntity
{
public string Name { get; set; }
}
public class School : Entity
{
public string Name { get; set; }
public List<MongoDBRef> Students { get; set; }
public List<MongoDBRef> Teachers { get; set; }
public MongoDBRef Master { get; set; }
}
以上案例:最终的记过就是Master,Teacher ,Student 会被包含在School 内,但是Teacher ,Student 老师并没有什么关联字段。
大致存储内容如下(手敲的结果,希望能看的懂):
{shcool:"_id":"342342345234rtwe5345","name":"河南大学",Student:[{"_id":"s423423423","name":"wyl","age":"26"}],"Teacher":[{"_id":"34345345"}......],"Mater"[{“id”:“4453453453”...........}]}
但是有没有发现一个问题,所有的学生和老师在同一个集合当中,但是老师和学生并没有集合,那么我们如果要查老师的集合或者学生的集合是不是麻烦的要死,我说的什么名表吗?select * from Teachets/Students。有人说我们可以件学生老师的对象,那样一对多的关系就在monggo文档中体现不出来了。
那怎么解决呢?
在类库中IDBRefContainer接口是对其的封装。远离就是在shcool查询Student。这不是废话吗?是的不过如果有更好的方法可以提出来。
代码 school.Pick<Student>(l=>l.name="wyl") 的形式。
2.3.MongoDB GridFS
1.GridFS 用于存储和恢复那些超过16M(BSON文件限制)的文件(如:图片、音频、视频等)。
2.GridFS 也是文件存储的一种方式,但是它是存储在MonoDB的集合中。
3.GridFS 可以更好的存储大于16M的文件。
4.GridFS 会将大文件对象分割成多个小的chunk(文件片段),一般为256k/个,每个chunk将作为MongoDB的一个文档(document)被存储在chunks集合中。
5.GridFS 用两个集合来存储一个文件:fs.files与fs.chunks。
6.每个文件的实际内容被存在chunks(二进制数据)中,和文件有关的meta数据(filename,content_type,还有用户自定义的属性)将会被存在files集合中。
此接口在类库IMongoFile中:
测试代码如下:
public void CreateFileTestCase()
{
//加载本地文件,并实例一个IMongoFile
IMongoFile file = MongoEntity.CreateFile<MyFile>(@"c:\pic1.jpg", "pic2.jpg", "jpg");
//下载文件,等同于文件另存为
file.Download(@"c:\beforesave.jpg");
//文件保存至数据库
file.Save();
//从数据中加载刚才保存的文件
IMongoFile fs = MongoEntity.LoadFile<MyFile>(file.Id);
//将从数据中加载的文件下载
fs.Download(@"c:\aftersave.jpg");
//根据数据库中的文件名检索文件
var files = MongoEntity.LoadAllFiles<MyFile>("pic2.jpg");
//根据文件id,将数据库中的文件下载到本地
MongoEntity.DownloadFile<MyFile>(file.Id, @"c:\copy.jpg");
Assert.AreEqual(file.Id, fs.Id);
Assert.AreEqual(1, files.Count);
Assert.AreEqual(file.Id, files[0].Id);
Assert.IsNull(file.MD5);
Assert.IsNotNull(fs.MD5);
Assert.AreEqual(file.Size, fs.Size);
Assert.AreEqual(file.Data, fs.Data);
}
基础拾遗-----mongoDB操作的更多相关文章
- 基础拾遗----RabbitMQ(含封装类库源码)
基础拾遗 基础拾遗------特性详解 基础拾遗------webservice详解 基础拾遗------redis详解 基础拾遗------反射详解 基础拾遗------委托详解 基础拾遗----- ...
- 基础拾遗----RabbitMQ
基础拾遗 基础拾遗------特性详解 基础拾遗------webservice详解 基础拾遗------redis详解 基础拾遗------反射详解 基础拾遗------委托详解 基础拾遗----- ...
- 基础拾遗------redis详解
基础拾遗 基础拾遗------特性详解 基础拾遗------webservice详解 基础拾遗------redis详解 基础拾遗------反射详解 基础拾遗------委托详解 基础拾遗----- ...
- 基础拾遗------webservice详解
基础拾遗 基础拾遗------特性详解 基础拾遗------webservice详解 基础拾遗------redis详解 基础拾遗------反射详解 基础拾遗------委托详解 基础拾遗----- ...
- 一点MongoDB的基础及mongodb在mac上的安装
最近发现维持写博客的习惯还是挺困难的,尤其对我来说,计划好的事过了好长时间才想到要去做. 这段时间一直在熟悉MongoDB,首先我是参考的这一篇:8天学通MongoDB 原博主写得非常好,我这里就 ...
- Java基础拾遗(二)
(尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/76358523冷血之心的博客) 马上就要秋招了,新的一轮笔试面试马上 ...
- Java基础拾遗(一)
(尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/76358391冷血之心的博客) 马上就要秋招了,新的一轮笔试面试马上 ...
- Python 面向对象之五 基础拾遗
Python 面向对象之五 基础拾遗 今天呢,就剩下的面向对象的相关知识进行学习,主要会学习以下几个方面的知识:1.上下文管理协议,2.为类加装饰器 3.元类 一.上下文管理协议 在学习文件操作的时候 ...
- WPF Multi-Touch 开发:基础触屏操作(Raw Touch)
原文 WPF Multi-Touch 开发:基础触屏操作(Raw Touch) 多点触控(Multi-Touch)就是通过与触屏设备的接触达到人与应用程序交互的操作过程.例如,生活中经常使用的触屏手机 ...
随机推荐
- Jquery实现数据双向绑定(赋值和取值),类似AngularJS
<!DOCTYPE html> <html> <head> <meta name="viewport" content="wid ...
- springboot自定义配置源
概述 我们知道,在Spring boot中可以通过xml或者@ImportResource 来引入自己的配置文件,但是这里有个限制,必须是本地,而且格式只能是 properties(或者 yaml). ...
- 深入理解计算机系统(4.2)------逻辑设计和硬件控制语言HCL
上一篇博客我们简单介绍了Y86指令集体系,而这篇博客我们将介绍指令集体系的逻辑设计和硬件控制语言HCL,为后面去实现Y86打下基础. 在硬件设计中,用电子电路来计算对位进行运算的函数,以及在各种存储器 ...
- 安装xp遇到的问题与如何连接共享的打印机
2013-12-5 星期四 今天下午去给曹老师鼓捣电脑去了,安装了一个xp系统,加上一些常用的办公软件,在连接上一个共享的打印机. 下面是今天我遇到的问题: 问题:安装xp系统之后,没有本地连接,只有 ...
- 张高兴的 UWP 开发笔记:手机状态栏 StatusBar
UWP 有关应用标题栏 TitleBar 的文章比较多,但介绍 StatusBar 的却没几篇,在这里随便写写.状态栏 StatusBar 用法比较简单,花点心思稍微设计一下,对应用会是个很好的点缀. ...
- 张高兴的 Xamarin.Android 学习笔记:(二)“Hello World”
完成环境配置后开始第一个简单项目.打开 Visual Studio 新建一个 Xamarin.Android 项目 "HelloAndroid".(GitHub:https://g ...
- checkbox插件
1.全选或者全不选 首先判断全选或全不选checkbox是否被选中. 如果被选中,则为每个选项checkbox设置obj.checked='checked'; 如果未被选中,则为每个选项checkbo ...
- Xamarin.Forms 开发IOS、Android、UWP应用
C#语言特点,简单.快速.高效.本次我们通过C#以及Xaml来做移动开发. 1.开发工具visual studio 2015或visual studio 2017.当然visual studio 20 ...
- 【ASP.NET MVC 学习笔记】- 14 HtmlHlper的扩展方法
本文参考:http://www.cnblogs.com/willick/p/3428413.html 1.在 MVC 中用于生成 Html 元素的辅助类是 System.Web.Mvc 命名空间下的 ...
- 快速部署MongoDB
MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案.本文安装的版本为3.0,其他版本可对照. 设置mongodb repo vi /e ...