Ich habe kürzlich mongodb recherchiert und online nach gesucht und festgestellt, dass Artikel über die Verwendung von mongodb in .net entweder frühe Treiberversionen sind, oder Es gibt nur sehr wenige Informationen, um es aufzuzeichnen. Dieser Artikel stellt Ihnen ausführlich vor, wie man MongoDB in .Net verwendet. Lassen Sie uns einen Blick darauf werfen.
Was ist MongoDB?
MongoDB basiert auf der Dokumentenspeicherung (keine Tabellen) und ist eine Kreuzung zwischen einer relationalen und einer nicht relationalen Datenbank Datenbank Die Produkte unter ihnen sind die funktionsreichsten unter den nicht relationalen Datenbanken und den relationalen Datenbanken am ähnlichsten. Die unterstützte Datenstruktur ist sehr locker und ein BSON-Format ähnlich json, sodass komplexere Datentypen gespeichert werden können. Das größte Merkmal von Mongo ist, dass die von ihm unterstützte Abfragesprache sehr leistungsfähig ist. Ihre Syntax ähnelt in gewisser Weise der Objektorientierten-Abfragesprache, die die meisten Funktionen ähnlich wie Single realisieren kann -Tabellenabfragen in relationalen Datenbanken und unterstützt auch die Erstellung eines Index für Daten. Mongo löst hauptsächlich das Problem der Zugriffseffizienz auf große Datenmengen. Da Mongo hauptsächlich die Massenspeicherung von Daten unterstützt, verfügt Mongo auch über ein hervorragendes verteiltes Dateisystem GridFS, das die Massenspeicherung von Daten unterstützen kann. Mongo erfreut sich großer Beliebtheit, da es komplexe Datenstrukturen unterstützen kann und über leistungsstarke Datenabfragefunktionen verfügt.
BSON ist das Datenspeicherformat von MongoDB. Jeder kennt JSON, aber was ist BSON? BSON basiert auf dem JSON-Format. Der Hauptgrund für die Wahl von JSON für die Transformation ist die Vielseitigkeit von JSON und die schemalosen Eigenschaften von JSON.
BSON hat die folgenden Eigenschaften
Schnellere Durchlaufgeschwindigkeit
Für das JSON-Format im Allgemeinen Sprich: Eine zu große JSON-Struktur führt dazu, dass die Datendurchquerung sehr langsam ist. Wenn Sie in JSON ein Dokument zum Lesen von Daten überspringen möchten, müssen Sie das Dokument scannen und einen problematischen Datenstrukturabgleich durchführen, z. B. einen Klammerabgleich. Eine wesentliche Verbesserung von BSON gegenüber JSON besteht darin, dass die Länge jedes Elements gespeichert wird im Kopf des Elements, sodass Sie nur die Länge des Elements lesen müssen, um direkt zum angegebenen Punkt zum Lesen zu suchen.
2. Einfachere Bedienung
Für JSON ist die Datenspeicherung untypisiert. Beispielsweise möchten Sie einen Grundwert von 9 auf 10 ändern, da aus einem Zeichen wird zwei, sodass der gesamte Inhalt danach möglicherweise um eine Position nach hinten verschoben werden muss. Mit BSON können Sie diese Spalte als numerische Spalte angeben. Unabhängig davon, ob die Zahl von 9 auf 10 oder 100 ansteigt, ändern wir nur das Bit, in dem die Zahl gespeichert ist, was nicht dazu führt, dass sich die Gesamtlänge der Daten ändert größer werden. Wenn in MongoDB die Zahl natürlich von einer Ganzzahl auf eine lange Ganzzahl ansteigt, erhöht sich natürlich immer noch die Gesamtdatenlänge.
3. Zusätzliche Datentypen hinzugefügt
JSON ist ein sehr praktisches Datenaustauschformat, aber seine Typen sind relativ begrenzt. BSON fügt auf seiner Basis den Datentyp „Byte Array“ hinzu. Dadurch entfällt die Notwendigkeit, Binärdaten vor dem Speichern in JSON in Base64 zu konvertieren. Der Rechenaufwand und die Datengröße werden erheblich reduziert. Natürlich hat BSON aufgrund des Typkonzepts manchmal keinen Platzvorteil gegenüber JSON.
MongoDB unter WindowsInstallation
Die Installation von MongoDB ist sehr einfach WeiterBis zum Ende der Installation ist die Installation des MongoDB-Dienstes die größte Gefahr. Hier sind einige Konfigurationsvorgänge nach der MongoDB-Installation
Erstellen Sie einen Datenbankpfad im Stammverzeichnis (Datenverzeichnis), Protokollpfad (Protokollverzeichnis), Protokolldatei (Mongo.log-Datei), Konfigurationspfad (Conf-Verzeichnis) Mein Installationspfad ist: D:Programm Datei smongodb
2 .Erstellen Sie dieKonfigurationsdatei mongo.conf im Verzeichnis conf. Der Inhalt der Datei lautet wie folgt:
logpath=D:\Program Files\mongodb\logs\mongodb.log #日志输出文件路径 logappend=true #错误日志采用追加模式,配置这个选项后mongodb的日志会追加到现有的日志文件,而不是从新创建一个新文件 journal=true #启用日志文件,默认启用 quiet=true #这个选项可以过滤掉一些无用的日志信息,若需要调试使用请设置为false port=27017 #端口号 默认为27017 auth=true #启用验证 需要用户名密码
mongod --config " D:\Program Files\mongodb\data \conf\mongo.conf"
mongod --config " D:\Program Files\mongodb\data \conf\mongo.conf" --install --serviceName "MongoDB" net start MongoDB
测试是否成功 可以在 浏览器中输入http://localhost:27017/如果出现下图表示服务安装成功
如果需要卸载MongoDB服务 在CMD 中运行
mongod.exe --remove --serviceName "MongoDB"
前期准备工作完成了,就可以开始撸代码了
如何在.net 中使用MongoDB
首先在项目中引入 MongoDB.Bson.dll,MongoDB.Driver.dll,MongoDB.Driver.Core.dll 我使用的是2.0版本的 现在好多文章都是介绍使用1+版本的 这也是我写此文的目的引入驱动DLL后,就可以开始撸代码了
部分代码如下
private static MongoClient client; private static IMongoDatabase database; //本地配置 private const string MongoDBConnectionStr = "mongodb://localhost"; //数据库名称 private static string DefaultDataBaseName = "Test"; public MongoDBHelper() { GetConnection(DefaultDataBaseName); } /// <summary> /// 构造函数 指定数据库 /// </summary> /// <param name="dataBaseName"></param> public MongoDBHelper(string dataBaseName) { GetConnection(dataBaseName); } private static void GetConnection(string dataBaseName) { client = new MongoClient(MongoDBConnectionStr); database = client.GetDatabase(dataBaseName); } /// <summary> /// 异步插入一条数据,手动输入collection name /// </summary> public Task InsertAsync<T>(string collectionName, T obj) { if (database == null) { throw new Exception("没有指定数据库"); } var collection = database.GetCollection<T>(collectionName); return collection.InsertOneAsync(obj); } /// <summary> /// 异步插入一条数据,采用类型T的完全限定名作为collection name /// </summary> public Task InsertAsync<T>(T obj) { return InsertAsync(typeof(T).FullName, obj); } /// <summary> /// 异步插入多条数据,手动输入collection name /// </summary> public Task BatchInsertAsync<T>(string collectionName, IEnumerable<T> objs) { if (database == null) { throw new Exception("没有指定数据库"); } if (objs == null) { throw new ArgumentException(); } var collection = database.GetCollection<T>(collectionName); return collection.InsertManyAsync(objs); } /// <summary> /// 异步插入多条数据,采用类型T的完全限定名作为collection name /// </summary> public Task BatchInsertAsync<T>(IEnumerable<T> objs) { return BatchInsertAsync(typeof(T).FullName, objs); } /// <summary> /// 插入一条数据 /// </summary> public void Insert<T>(T obj) { InsertAsync(obj).Wait(); } /// <summary> /// 插入多条数据 /// </summary> public void Insert<T>(IEnumerable<T> objs) { BatchInsertAsync(objs).Wait(); } /// <summary> /// MongoDB C# Driver的Find方法,返回IFindFluent。手动输入collection name /// </summary> public IFindFluent<T, T> Find<T>(string collectionName, FilterDefinition<T> filter, FindOptions options = null) { if (database == null) { throw new Exception("没有指定数据库"); } var collection = database.GetCollection<T>(collectionName); return collection.Find(filter, options); } /// <summary> /// MongoDB C# Driver的Find方法,返回IFindFluent。采用类型T的完全限定名作为collection name /// </summary> public IFindFluent<T, T> Find<T>(FilterDefinition<T> filter, FindOptions options = null) { return Find(typeof(T).FullName, filter, options); } /// <summary> /// 取符合条件的数据 sort中多个排序条件逗号分隔,默认asc /// </summary> public List<T> Get<T>(Expression<Func<T, bool>> condition, int skip, int limit, string sort) { return Get(new List<Expression<Func<T, bool>>> { condition }, skip, limit, sort); } public List<T> Get<T>(Expression<Func<T, bool>> condition) { return Get(condition, 0, 0, null); } /// <summary> /// 取符合条件的数据 sort中多个排序条件逗号分隔,默认asc /// </summary> public List<T> Get<T>(List<Expression<Func<T, bool>>> conditions, int skip, int limit, string sort) { if (conditions == null || conditions.Count == 0) { conditions = new List<Expression<Func<T, bool>>> { x => true }; } var builder = Builders<T>.Filter; var filter = builder.And(conditions.Select(x => builder.Where(x))); var ret = new List<T>(); try { List<SortDefinition<T>> sortDefList = new List<SortDefinition<T>>(); if (sort != null) { var sortList = sort.Split(','); for (var i = 0; i < sortList.Length; i++) { var sl = Regex.Replace(sortList[i].Trim(), @"\s+", " ").Split(' '); if (sl.Length == 1 || (sl.Length >= 2 && sl[1].ToLower() == "asc")) { sortDefList.Add(Builders<T>.Sort.Ascending(sl[0])); } else if (sl.Length >= 2 && sl[1].ToLower() == "desc") { sortDefList.Add(Builders<T>.Sort.Descending(sl[0])); } } } var sortDef = Builders<T>.Sort.Combine(sortDefList); ret = Find(filter).Sort(sortDef).Skip(skip).Limit(limit).ToListAsync().Result; } catch (Exception e) { //异常处理 } return ret; } public List<T> Get<T>(List<Expression<Func<T, bool>>> conditions) { return Get(conditions, 0, 0, null); }
示例代码中只实现了插入和查询功能,后续会将完整代码上传
总结
本文只记录了MongoDB的最基本使用,后续会介绍副本级,主从自动备份等机制与实现方式,感兴趣的朋友们请继续关注脚本之家,谢谢大家对脚本之家的支持。
Das obige ist der detaillierte Inhalt vonTutorial zur Verwendung von MongoDB in .Net. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!