Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

C# Mongodb. Sum field for all documents

Tags:

c#

mongodb

I need to calculate total for all document in the collection. For example, I have the following three documents:

_id: 1,
clientId: 1,
cash: 500

_id: 2,
clientId: 1,
cash: 100

_id: 3,
clientId: 2,
cash: 200

So, I want to sum cash field for the specific clientId. For the client 1 I want to get 600, for the client 2 I wanto get 200. It's my first usage of aggregation frameworkd in MongoDB. I checked documentation and the other questions from SO, but can't figure out, why I have to use group clause. Why do I need it, if just want to sum. I event tried to use Group but can't get it compile:

_collection.Aggregate().Match(t=>t.ClientId == 1).Group(null, g => new
            {
                Total = g.Sum(o => o.Cash)
            });

No overload for method 'Group' takes 2 arguments

PS. I don't want to use BsonDocument and such thing like $sum keywords. I want to make it in more C# way.

like image 932
user348173 Avatar asked Sep 19 '17 07:09

user348173


People also ask

What C is used for?

C programming language is a machine-independent programming language that is mainly used to create many types of applications and operating systems such as Windows, and other complicated programs such as the Oracle database, Git, Python interpreter, and games and is considered a programming foundation in the process of ...

What is C full form?

Full form of C is “COMPILE”. One thing which was missing in C language was further added to C++ that is 'the concept of CLASSES'.

Is C language easy?

C is a general-purpose language that most programmers learn before moving on to more complex languages. From Unix and Windows to Tic Tac Toe and Photoshop, several of the most commonly used applications today have been built on C. It is easy to learn because: A simple syntax with only 32 keywords.

What is C language basics?

What is C? C is a general-purpose programming language created by Dennis Ritchie at the Bell Laboratories in 1972. It is a very popular language, despite being old. C is strongly associated with UNIX, as it was developed to write the UNIX operating system.


1 Answers

is this ok?

var Total = _collection.AsQueryable().Where(x => x.ClientId == 2).Sum(x => x.Cash);

EDIT: aggregate is overkill here but it would go maybe like this:

var x = MongoCollection.Aggregate()
                    .Group(
                            doc => doc.clientId,
                            group => new
                            {
                                clientId = group.Key,
                                Total = group.Sum(y => y.sum)
                            }
                    ).ToList().FirstOrDefault(c => c.clientId == 2).Total;

aggregation is executed in Db until it goes toList()

like image 54
BOR4 Avatar answered Oct 10 '22 12:10

BOR4