Skip to main content

MongoDB_01

    After some practice on ReactJS, moved back to NodeJS. Interactive design is pale if it can only play alone. Quite often, ReactJS, NodeJS are written together with SQL or nonDB (NoSQL Database) on job description. MongoDB is a famous nonDB.

    I'm using external MongoDB on https://account.mongodb.com/account/login. Topic related to npm installation, please refer to https://www.w3schools.com/nodejs/nodejs_mongodb.asp My .js codes connect to MongoDB via URI string. Confidential information is encapsulated in a class object as a required file.

    So, here we go! My exercises follow w3schools's tutorial, but designed in much simple way. To me, "simple" doesn't only mean "short". Clean slate also plays an important role. I may use embed function as few as possible.

Create Connection 


The MangoClient.connect() API is different from what is on w3school's tutorial. And when I did research, it take me a while to reach the current API documentation, v3.5
NodeJS's MongoDB API v3.5

Since I quite often get v.1.8/1.9 API, probably still some programmers doesn't notice that connect() takes different parameters....
API documentation is quite profound. Usually I define callback functions according to API Docs. ie. the 2nd parameter of connection()'s callback function is connection object.

Create DB, Collection



I don't think MongoDB really cares whethere db or collection is created, if there is nothing inside.... Don't know. Din't have time to try. As I can see,  conn.db(dbName) doesn't really make any call to db host, and then it create a collection with specified db name. As we can see later on, I can also set a nested document even when the structure wasn't defined yet. But only one layer. Maybe I can try to set value cross multi-layers someday.....

Usually I don't use the collection object returned by db.createCollection()'s callback.
kimetsu..... Can refere to Kimetsu no Yaiba 😜


Close Connection 



Always remember to close connection at the end. This is a good habit.


Insert Record



There are insertOne() and insertMany()
I prefer to use insertMany() since it can also insert only one record.

I intentionally design a  complex structure. Though it is not ideal, probably redundant... Many tutorial provide key-value, hash-table like structure which is not very practical in my work. I need to use complicated structure, and must be able to manipulate it.

There are string, array and nested object in design.

Query Records


I found query is rather difficult, comparing to SQL..... Quite often, I couldn't get anything if I didn't precisely match the value. Then what is the query for? if I must know everything! Alright... it's because I'm not very familiar with nonDB. I tried to use  regular expression to retrieve multiple data, with rule such like 'there are "er" in string'....... Anyway, it is a good chance to practice regular expression. (Maybe too few records is also one of my troubles.)

Query Nested Structure




Query a nested structure, key names be refereed as dot-connected string.
As regular expression, the definition string needs no quotes.
find() function doesn't return records, it only return a cursor. toArray() function processes the cursor and passes data to callback function.

Query Array


Query on array element is similar to query a string.
project() function decide which column to or not to return. It is a cursor process function; doesn't process the result. It hands data to toArray() to deal with decipher.


Sort Query 


sort() function decide ascend or descend order. It is only a cursor process function, too.



Comments

Popular posts from this blog

Bookmark service (MongoDB & Spring REST) -2/2

    I accidentally deleted my development VM. I got lucky having the habit of taking notes. This blog is useful. Development VM is doom to be lost. Rebuild it waste time, but having a clean slate is refreshing~. What concerns me more is my AWS free quota this month is reaching 85%. The second VM I launched but never being used might be the one to blame. (Of course, my mistake.) I terminated the wrong VM. Now I got Linux 2 built. Great, just threw away everything happened on AMI.  1st layer: Page Page class   Originally, I need to prepare getter/setter for all class properties for Spring. By using lombok, I only need to create constructors. lombok will deal with getter/setter and toString(). But there are chances to call getter/setter, but how? .......Naming convention.... Capitalize the 1st character with the prefix get/set.  Annotation @Data was used on this class.  Repository class Spring Docs: Repository https://docs.spring.io/spring-data/mongodb/docs/3....

Guide to Preserving HuggingFace Models in Google Colab Environments

Conclusion:  Step 1:  find the model path: ls ~/.cache  Step 2:  Copy the entire folder to Google Drive:  Step 3:  Set model path to the subfolder under snapshot: My Story: I initially began exploring Generative AI (GAI) and Google Colab through Stable Diffusion. In the past, as I mainly wrote server services and console applications, I was less familiar with data science modes like R and Jupyter that can maintain a paused state. I didn't quite understand the heavy burden on Colab of creating a temporary Stable Diffusion WebUI with .ipynb, as suggested by popular guides. I just found it troublesome that connections often took a long time and then dropped, requiring a restart. Recently, while testing new versions of the Stable Diffusion model, and facing challenges due to Colab's policies making various versions of WebUI difficult to run successfully, I started researching how to write my own test programs in Colab. Eventually, I understood that Colab is ess...

Setup Maven and two basic projects

    The interesting implementation of Java I proceed to is Spring. And, only getting Java running is not enough. I also need to set up Maven. This name is new to me, and I found many Spring tutorials just skip this part. At least I need Maven to generate templates for me. I should learn it more. ( I knew there is a great tool -- Eclipse -- can make tedious things disappear. I’m taking a strategy to install all experiments I want to try and throw away when it's full. And that's an external VM, not my PC. I, not yet, want to do research about installing Eclipse on AMI. )    Upgrade to Java 8     First is to upgrade Java on AMI to Java8. AWS provides advanced tools for Linux 2. And DIY for Linux2. At least there are solutions for my choice.  Amazon Corretto 8 Installation Instructions for Amazon Linux 2 https://docs.aws.amazon.com/corretto/latest/corretto-8-ug/amazon-linux-install.html Here are commands I used: >wget */amazon-corretto-8-x64-linux-jdk.d...