ColinChang.MongoHelper 1.0.0

dotnet add package ColinChang.MongoHelper --version 1.0.0                
NuGet\Install-Package ColinChang.MongoHelper -Version 1.0.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="ColinChang.MongoHelper" Version="1.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add ColinChang.MongoHelper --version 1.0.0                
#r "nuget: ColinChang.MongoHelper, 1.0.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install ColinChang.MongoHelper as a Cake Addin
#addin nuget:?package=ColinChang.MongoHelper&version=1.0.0

// Install ColinChang.MongoHelper as a Cake Tool
#tool nuget:?package=ColinChang.MongoHelper&version=1.0.0                

This is a MongoDB operation utility based on MongoDB.Driver like the SqlHelper for relation database.It provides the usual CRUD methods.Query for ordered paged and big data are also supported.Index management also included.

Details of how to use it,please check the unit test project.

Serialize & Deserialize

When a Generic method like Task<IEnumerable<T>> QueryAsync<T>() is invoked,MongoDriver will try to deserialize the query result to an object of type provided.When the type of the object is complex,it may result in some unexpected exceptions.

  • Numbers.Use long instead of int.Use double instead of float
  • ObjectId. When the object has an ObjectId type member,a custom ObjectIdConverter is required.You can also use ColinChang.MongoHelper.JsonConvert simply to handle this.
  • Subclass. MongoDriver is not friendly for subclass when deserialize to object.try to use interface rather than BaseClass.
  • Unmapped members.When the type of your object is not complete mapped with the data from mongo.You should map both of them before invoking mongohelper.
var mongo =
    new MongoHelper("mongodb://127.0.0.1","TestDb");
        
BsonClassMap.RegisterClassMap<ImageResult>(map =>
{
    map.AutoMap();
    map.SetIgnoreExtraElements(true);
    map.MapIdField(p => p.Id);
    map.UnmapMember(p=>p.Key);
    
    point.MapProperty(p => ir.UserName).SetElementName("name");
});

check more details here

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.0 684 3/23/2019