Przejdź do głównej zawartości

MongoDB for C# developers - Lesson 1

Today I'll show you what I lerned at Mongo University online course for C# developers after first lesson and passing all homework.
I'll show you how you can:
- install MongoDB on Windows workstation
- switch between databases
- display all elements from a collection
- add new document to a collection
- restore Mongo database from a dump folder.


Get MongoDB installer from MongoDB download center:
https://www.mongodb.com/download-center

After installation of 64 bit version go to C:\Program Files\MongoDB\Server\3.4\bin.
You should see there 2 files:
-mongo - this is a console application, you can think of it as a client application
-mongod - this is a server of database

At this point it's useful to add 'C:\Program Files\MongoDB\Server\3.4\bin' to PATH environment variable.


Now open the command line and go to C drive.
Create the folder by using command:
mkdir data\db
And now run the server:
mondog
Important: If you forget adding the data\db folder then server will stop just after starting.
It's very important directory. Mongo needs it to be created because this is where Mongo stores its files including your collections.
It's important to note that data are stored by MongoDB in BSON(binary JSON) format.

Now as mongo server is running, we can run this from different window:
db.users.insert({"name" : "Dariusz Kacban" })
db.users.insert({"name" : "Someone Else" })

We simply add 2 JSON objects to "users" collection. In our example all values are strings.
Fortunately JSON allow for exactly 4 data types: string, number, array or JSON object itself.

And to confirm that 2 rows were added to the 'users' collection run this command:
db.users.find()


Useful commands after running mongo client application are available when you type in help.
The are commands like:
show dbs - show all databases
use test - use specific database
db.users.insertOne({JSON OBJECT HERE}) - if test db doesn't exist - mongo wil create it for us.
db.users.find().pretty() - display entire 'users' collection
db.users.find({"name":"Dariusz"}).pretty() - display only users with name "Dariusz"

It's worth to mention than 16MB is maximum size od a document in Mongo. It must be considered when you make a decision if to embed data in a collection or create a separate collection. This is MongoDB requirement.

Another useful function od MongoDB is: mongoestore. It helps you to restore data from dump file that you've previously created.
Example use: mongorestore dump_directory

Then you need to switch to database like this:
use database_name

then you call collections like this:
db.colelction_name.find()

One important note: expressing string in JSON demands that you use " instead of '.


That's all for today. I hope you like to learn Mongo and want to learn how to design a database in Mongo and how Mongo work in comparison to relational database like MySQL or Oracle.

If you're interested find the course and join the next edition: https://university.mongodb.com/

Komentarze

Popularne posty z tego bloga

Unleash the power of ChatGPT in your C# applications with NGpt - C# OpenAI GPT client

Meet NGpt - OpenAI GPT C# client library that will make your conversations with ChatGPT a breeze! Have you ever been struggling building your own smart AI application in C#? Well, now you can use ChatGpt inside your application! Introducing NGpt, the powerful .NET library that lets you integrate ChatGPT seamlessly into your C# applications. No more nigts spent on building your own AI solitions, no more convoluted logic and building complex business rules - just pure AI bliss. In this blog post, we'll dive into the wonderful world of NGpt and show you how easy it is to use. You might even find a few laughs along the way. The Magic of NGpt NGpt is a transient fault-tolerant .NET 6 OpenAI client that simplifies ChatGPT integration for C# developers. It's like your friendly neighborhood Spider-Man - always there to help you out when you need it most. With just your OpenAI API key, you can start coding AI applications in C# faster than you can say "Peter Parker." Let&

Specflow czyli BDD w praktyce

Dzisiaj pokażę w praktyce w jaki sposób zbieram wymagania korzystając z narzędzia Specflow. Na początku przypomnę nasze historie użtkownika. Potem skonfigurujemy dodatek Specflow Visual Studio. Na końcu pokażę jak wygląda język Gherkin i zaimplementujemy pierwszą historię użytkownika US1. Oto lista funkcjonalności, które będę implementował w aplikacji Perfect Life: US1: Jako użytkownik aplikacji mobilnej chcę ekran logowania aby mieć możliwość zapisywania swoich postępów US2: Jako użytkownik aplikacji mobilnej chcę mieć kalkulator wskaźnika BMI aby móc mierzyć poziom swojej kondycji US3: Jako użytkownik aplikacji mobilnej chcę widzieć wykresy aby móc wizualnie interpretować swoje postępy US4: Jako użytkownik aplikacji mobilnej chcę mieć możliwość rozwiązania quizu, żeby zbadać wskaźnik Body Age US5: Jako użytkownik aplikacji mobilnej chcę pobierać pliki PDF aby mieć dostęp do planów dietetycznych US6: Jako administrator aplikacji chcę zapisywać dane telemetryczne aby móc an

How to call webAPI service in Xamarin?

In the last few weeks I worked on the web service written in ASP.NET Core. I had a plan to connect the Xamarin application to this web service. Today I'll show you how you can connect your Xamarin app to web service located anywhere in the cloud. First we need to have a web service deployed, which is our server-side part of the system. I describe how to create a web service in ASP.NET COre in my previous post: . Today I'll demonstrate how it works from client perspective, in our case it's Xamarin.Forms application but web application or desktop application can use exactly the same code. This is the great benefit of using C# language - we can use the same code on multiple platforms. OK, I bet you're interested in the code. Let's jump to the code. This is the final version of the client class that I can use to save and retrieve data from web service: The class design is straightforward. It has 2 public methods which encapsulate 2 functionalities: adding s