Heim > Backend-Entwicklung > C#.Net-Tutorial > Tutorial zur Verwendung von MongoDB in .Net

Tutorial zur Verwendung von MongoDB in .Net

黄舟
Freigeben: 2017-05-28 10:18:37
Original
2052 Leute haben es durchsucht

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 die

Konfigurationsdatei 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 #启用验证 需要用户名密码
Nach dem Login kopieren
Nachdem Sie die beiden oben genannten Schritte ausgeführt haben, Sie können MongoDB starten.

Führen Sie CMD aus. Geben Sie den Befehl ein (beachten Sie den Pfad von mongod).

mongod --config " D:\Program Files\mongodb\data \conf\mongo.conf"
Nach dem Login kopieren
3. Erstellen und starten Sie den MongoDB-Dienst Wird es ziemlich mühsam sein, wenn Sie Schritt drei jedes Mal ausführen? Befolgen Sie den folgenden Befehl, um ihn zu erstellen. Und starten Sie den MongoDB-Dienst. Sie können das Starten und Herunterfahren von MongoDB über den Windows-Dienst verwalten

mongod --config " D:\Program Files\mongodb\data \conf\mongo.conf" --install --serviceName "MongoDB"

net start MongoDB
Nach dem Login kopieren

测试是否成功 可以在 浏览器中输入http://localhost:27017/如果出现下图表示服务安装成功

如果需要卸载MongoDB服务 在CMD 中运行

mongod.exe --remove --serviceName "MongoDB"
Nach dem Login kopieren

前期准备工作完成了,就可以开始撸代码了

如何在.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(&#39;,&#39;);

   for (var i = 0; i < sortList.Length; i++)

   {

    var sl = Regex.Replace(sortList[i].Trim(), @"\s+", " ").Split(&#39; &#39;);

    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);

}
Nach dem Login kopieren

示例代码中只实现了插入和查询功能,后续会将完整代码上传

总结

本文只记录了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!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage