Book Image

Building Applications with Spring 5 and Vue.js 2

By : James J. Ye
Book Image

Building Applications with Spring 5 and Vue.js 2

By: James J. Ye

Overview of this book

Building Applications with Spring 5 and Vue.js 2, with its practical approach, helps you become a full-stack web developer. As well as knowing how to write frontend and backend code, a developer has to tackle all problems encountered in the application development life cycle – starting from the simple idea of an application, to the UI and technical designs, and all the way to implementation, testing, production deployment, and monitoring. With the help of this book, you'll get to grips with Spring 5 and Vue.js 2 as you learn how to develop a web application. From the initial structuring to full deployment, you’ll be guided at every step of developing a web application from scratch with Vue.js 2 and Spring 5. You’ll learn how to create different components of your application as you progress through each chapter, followed by exploring different tools in these frameworks to expedite your development cycle. By the end of this book, you’ll have gained a complete understanding of the key design patterns and best practices that underpin professional full-stack web development.
Table of Contents (23 chapters)
Title Page
Copyright and Credits
Dedication
About Packt
Contributors
Preface
Index

Physical data modeling for MongoDB


Data stored in MongoDB has a very flexible schema. When we do the physical data modeling for MongoDB, instead of defining the structure of schemas, we write validators to enforce the rules on the fields that we have in our data model. In this way, we can make sure that each document in the collection will have those required fields we specified in the validator and they will be in the data type we require. And, as a naming convention of MongoDB, all of the collection's names will be plural, for example, User entities will be stored in collection users.

Let's look at an example; the following is a MongoDB script (for MongoDB Version 3.6 and later) that is used to create the teams collection. As you can see, most of this script is defining validation rules:

db.createCollection( "teams",{
    "storageEngine": {"wiredTiger": {}},
    "capped": false,
    "validator": {
        "$jsonSchema": {
            "bsonType": "object",
            "additionalProperties...