What is a Database Management System? Tools, Techniques and Optimization

By Rohit Sharma

Updated on Mar 03, 2025 | 17 min read | 1.87K+ views

Share:

Database Management Systems (DBMS) offer structured data storage, improving retrieval speed compared to conventional file systems. They have revolutionized industries like healthcare, where EMR systems ensure accurate patient records and easy data sharing.

According to Verified Market Research, the DBMS market is projected to reach USD 149.23 billion by 2030, growing at a CAGR of 12.83% from 2024. This emphasizes its relevance despite scalability and cost challenges.

In this blog, you’ll explore what a database management system is, its tools, and optimization techniques.

What is a Database Management System? Features, Types, and Components

Database Management System (DBMS) is software that provides a structured and efficient way to store, manage, and obtain data. The data is organized into tables with defined relationships, ensuring consistency, integrity, and security. 

Users can manipulate data using query languages like SQL without worrying about low-level storage details.

DBMS overcomes the challenges of file-based storage by ensuring data consistency and providing better data security.

DBMS helps businesses manage growing data efficiently, ensuring structured storage and better decision-making. Let’s look at the uses of DBMS in different industries.

  • Banking: DBMS manages customer accounts, transactions, and loan records securely while preventing fraud through real-time monitoring and access controls.
  • Healthcare: By organizing patient records, medical histories, prescriptions, and billing information, it ensures data accuracy and compliance with regulations.
  • E-commerce: DBMS can track inventory, manage user profiles, process transactions, and personalize customer recommendations based on purchasing behavior.
  • Government: It maintains citizen records, tax data, and administrative workflows, supporting transparency, efficient governance, and secure data access.
  • Education: DBMS can store student records, course enrollments, faculty details, and examination results, allowing efficient academic management and reporting.

Data Science Courses to upskill

Explore Data Science Courses for Career Progression

background

Liverpool John Moores University

MS in Data Science

Double Credentials

Master's Degree17 Months

Placement Assistance

Certification6 Months

Master the fundamentals of DBMS, along with data science concepts, and apply them to real-world database management and analytics challenges. Enroll in upGrad’s Online Data Science Course now!

Next, let’s explore key DBMS features like data storage and integrity, which enhance the performance of database management systems.

Key Features of Database Management System

Database management systems can store, manage, and retrieve data efficiently through features like data integrity, abstraction, and optimization.

Here are the features of a database management system.

  • Data Modeling: Defines the logical structure of data using entities, relationships, and constraints. For example, in healthcare, an ER model helps hospitals to manage patient records, doctor assignments, and medical histories.
  • Data Storage: Stores large volumes of structured data in tables, ensuring easy retrieval. In e-commerce, DBMS stores stock levels, product details, and order histories, allowing businesses to manage inventory in real time.
  • Update and Retrieval: Supports efficient data modification and retrieval through queries. In banking, customers can update their contact details while immediately retrieving account statements through online banking systems.
  • Concurrency Control: Handles simultaneous database access, preventing conflicts and ensuring accuracy. In stock trading platforms, multiple users can place buy and sell orders simultaneously without data inconsistencies.
  • Data Integrity and Security: Enables consistency, accuracy, and restricted access through authentication and encryption. In government databases, sensitive citizen records, such as social security numbers, are protected from unauthorized access.
  • Backup and Recovery: Protects data by creating backups and restoring it after failures. In financial services, regular backups prevent data loss due to unexpected system crashes or cyberattacks.
  • Transaction Management: Maintains ACID (Atomicity, Consistency, Isolation, Durability) properties for reliable transactions. In online banking, when a customer transfers money, the transaction is either completed fully or is rolled back if interrupted.
  • Data Abstraction and Independence: Separates data from application logic, allowing flexibility. In cloud-based customer relationship management (CRM) systems, businesses can update software versions without affecting stored customer records.
  • Data Definition and Schema Management: Allows defining and modifying database schemas without affecting existing data. In education, universities can update course structures or add new programs without losing old student records.
  • Query Processing and Optimization: Improves database performance by optimizing query execution. In logistics, optimized SQL queries fetch real-time shipment tracking details, improving delivery efficiency.

Also Read: 20 Most Common SQL Query Interview Questions & Answers [For Freshers & Experienced]

After examining the key features of database management systems, let’s now explore the different types of database management systems.

What are the Different Types of Database Management System?

Some common DBMS models include Relational DBMS, NoSQL DBMS, Distributed DBMS, and Object-Oriented DBMS.

Here are the different types of database management systems.

  • Relational DBMS (RDBMS)

RDBMS organizes data into structured tables with predefined relationships, using SQL for handling data. It supports data integrity and allows complex queries, making it suitable for transactional applications. 

Use Case: In banking, RDBMS like MySQL and PostgreSQL can manage customer accounts, transactions, and financial records securely.

Example: MySQL, PostgreSQL, Oracle DB

Learn the fundamentals of relational database design and understand how to efficiently structure data using MySQL for real-world applications. Join the free course on Introduction to Database Design with MySQL.

  • NoSQL DBMS

NoSQL databases can handle unstructured or semi-structured data, making them highly scalable and flexible. They are widely used in applications that need high-speed data access and real-time updates. 

Use Case: Social media platforms use NoSQL databases like MongoDB and Firebase to handle dynamic user-generated content efficiently.

Example: MongoDBFirebase, Cassandra

Also Read: Cassandra vs MongoDB: Difference Between Cassandra & MongoDB [2024]

  • Object-Oriented DBMS (OODBMS)

OODBMS stores data as objects, integrating easily with object-oriented programming languages like Java and C++. It is beneficial for applications that need complex data modeling.

Use Case: In gaming, OODBMS like db4o and ObjectDB manage in-game objects, 3D models, and media assets.

Example: db4o, ObjectDB, Versant

  • Distributed DBMS

A Distributed DBMS manages a database across multiple servers, supporting fault tolerance and high availability. It is used in large-scale systems that need seamless data access from multiple locations. 

Use Case: Cloud services use Distributed DBMS to maintain data consistency across global servers, improving performance.

Example: Google Spanner, Apache Cassandra, Amazon DynamoDB

  • Cloud-native Databases

Cloud-native databases are optimized for cloud environments, offering automatic scaling, high availability, and fault tolerance.

Use Case: Used in applications that need dynamic scaling and rapid deployment, like e-commerce platforms and SaaS applications.

Example: Amazon Aurora, Google Cloud Spanner, Microsoft Azure Cosmos DB

Also Read: DBMS vs. RDBMS: Understanding the Key Differences, Features, and Career Opportunities

With an understanding of different types of database management systems like NoSQL and RDBMS, let’s explore the components of a DBMS.

What are the Components of DBMS?

A database management system consists of hardware components such as servers, software like operating systems, and interacting entities such as database administrators.

Here are the different components of the database management system.

  • Hardware 

Provides the necessary computing power and storage to handle large datasets efficiently. It includes servers, storage devices, and network hardware to ensure smooth database operations.

Example: Database servers like Oracle Exadata or cloud-based storage solutions like AWS RDS.

  • Software

The set of programs that allow users to store, retrieve, and manipulate data while enforcing security and consistency.

Example: DBMS software like PostgreSQL, MySQL, and Microsoft SQL Server.

  • Data

It consists of raw facts, records, and information stored in structured formats such as tables, documents, or graphs. They serve as the bedrock of database systems.

Example: Customer transaction records in banking or product catalogs in e-commerce.

  • Procedures

The set of rules and guidelines for database operation, management, and maintenance. These include recovery methods, data backup protocols, and user access policies.

Example: Financial institutions implement daily automated backups using Oracle RMAN or IBM Db2’s backup utilities to ensure customer transaction data is securely stored.

  • Database Access Query Language

A specialized language that helps you to interact with and manipulate the database, such as SQL or NoSQL query languages.

Example: SQL queries like SELECT * FROM customers in relational databases or MongoDB’s NoSQL queries for document retrieval.

  • Users

The individuals or applications that interact with the database, including database administrators, developers, and end-users.

Example: A bank employee accessing customer account details or an AI system querying a database for predictive analytics.

Now that you’ve explored what is database management system, let’s check out the different types of database languages.

Understanding Database Languages: Types, Functions, and SQL Commands

DBMS uses languages such as Data Definition Language (DDL) and Data Control Language (DCL) to define, manipulate, control, and retrieve data efficiently.

Here are the different types of database languages used in DBMS.

Data Definition Language (DDL)

DDL commands are responsible for creating, modifying, and deleting database objects like tables, views, and indexes. The commands are automatically committed and cannot be rolled back.

Here are the different commands:

  • CREATE: Defines a new table, database, index, or view.

Example: CREATE TABLE employees (id INT PRIMARY KEY, name VARCHAR(50), salary DECIMAL(10,2), department VARCHAR(30));

  • ALTER: Modifies an existing database object, such as adding or dropping columns.

Example: ALTER TABLE employees ADD COLUMN hire_date DATE;

  • DROP: Permanently removes a database object, deleting both its structure and data.

Example: DROP TABLE employees;

  • TRUNCATE: Deletes all rows from a table while preserving its structure, making it faster than DELETE.

Example: TRUNCATE TABLE employees;

  • COMMENT: Adds descriptions or notes to database objects for better understanding.

Example: COMMENT ON TABLE employees IS 'Stores employee information';

  • RENAME: Changes the name of a database object like a table or column.

Example: RENAME employees TO staff;

Data Manipulation Language (DML)

DML commands can retrieve, insert, update, and delete records. DML operations can be rolled back using TCL (Transaction Control Language).

Here are the different commands:

  • SELECT: Fetches data from tables based on specified conditions.

Example: SELECT name, salary FROM employees WHERE department = 'HR';

  • INSERT: Adds new records to a table.

Example: INSERT INTO employees (id, name, salary, department) VALUES (1, 'Alice', 50000, 'HR');

  • UPDATE: Modifies existing records based on conditions.

Example: UPDATE employees SET salary = 55000 WHERE id = 1;

  • DELETE: Removes records from a table while keeping the structure intact.

Example: DELETE FROM employees WHERE id = 1;

  • MERGE: Combines INSERT, UPDATE, and DELETE operations, useful in data warehousing.

Example: MERGE INTO employees USING new_data ON employees.id = new_data.id WHEN MATCHED THEN UPDATE SET employees.salary = new_data.salary;

  • CALL: Executes a stored procedure or function to perform database operations.

Example: CALL update_salary(1, 60000);

  • EXPLAIN PLAN: Analyzes how a query will be executed, useful for performance tuning.

Example: EXPLAIN PLAN FOR SELECT * FROM employees;

  • LOCK TABLE: Prevents simultaneous modifications to ensure data consistency.

Example: LOCK TABLE employees IN EXCLUSIVE MODE;

Data Control Language (DCL)

DCL manages user access and permissions in a database. It controls who can perform operations like reading, modifying, or deleting data.

Here are the different commands:

  • GRANT: Provides specific privileges to a user or role.

Example: GRANT SELECT, INSERT ON employees TO user1;

  • REVOKE: Removes previously granted permissions from a user or role.

Example: REVOKE INSERT ON employees FROM user1;

Transaction Control Language (TCL)

TCL maintains consistency and integrity. Transactions ensure that multiple operations are executed completely or not at all.

Here are the different TCL commands:

  • COMMIT: Saves all changes made in the current transaction permanently.

Example: COMMIT;

  • ROLLBACK: Reverts changes made in the current transaction to the last committed state.

Example: ROLLBACK;

  • SAVEPOINT: Creates a temporary save point within a transaction, allowing partial rollbacks.

Example: SAVEPOINT sp1; UPDATE employees SET salary = 70000 WHERE id = 2; ROLLBACK TO sp1;

Data Query Language (DQL)

DQL retrieves information from a database. It allows users to filter, sort, and analyze stored data efficiently.

Here are the commands used in DQL:

  • SELECT: Fetches data based on conditions, allowing complex queries with filtering, sorting, and aggregation.

Example: SELECT name, department FROM employees WHERE salary > 50000;

  • WHERE: Filters data based on conditions.

Example: SELECT name FROM employees WHERE salary > 50000;

  • ORDER BY: Sorts query results.

Example: SELECT name, salary FROM employees ORDER BY salary DESC;

  • GROUP BY: Groups records with aggregate functions.

Example: SELECT department, AVG(salary) FROM employees GROUP BY department;

  • HAVING: Filters grouped results.

Example: SELECT department, AVG(salary) FROM employees GROUP BY department HAVING AVG(salary) > 60000;

  • JOIN: Combines data from multiple tables.

Example: SELECT employees.name, departments.department_name FROM employees JOIN departments ON employees.department_id = departments.id;

Having explored the different database languages, let’s check out the major tools used in database management systems.

Subscribe to upGrad's Newsletter

Join thousands of learners who receive useful tips

Promise we won't spam!

Top Database Management Tools for Efficient Data Handling

Database management tools like IBM DB2 manage large-scale enterprise databases, while MySQL is widely used for query execution. 

Here are the top database management tools used for efficient data handling.

Tool Details 
SolarWinds Database Performance Analyzer

Performance monitoring and tuning tool that provides deep insights into query execution, bottlenecks, and system health.

Use case: Detects slow SQL queries in a banking system and suggests index optimizations to improve response times.

IBM DB2

This AI-integrated relational database system can handle large-scale enterprise data across cloud and on-premises environments.

Use case: A bank system uses IBM DB2 to process millions of daily transactions while ensuring data consistency and fraud detection.

Microsoft SQL Server

It is a relational database system that offers advanced analytics, business intelligence, and cloud integration for enterprise applications.

Use case: Hospitals use SQL Server to store and retrieve patient data, ensuring real-time access for doctors and nurses.

MySQL

It is an open-source relational database system known for its speed, flexibility, and ease of use, making it suitable for web applications.

Use case: Online stores use MySQL to handle customer orders, ensuring easy shopping cart updates and payment processing.

Oracle RDBMS

This enterprise-grade database management system is known for its high availability, scalability, and advanced security features.

Use case: MNCs use Oracle RDBMS to centralize financial data from multiple subsidiaries, ensuring real-time reporting and compliance.

Amazon RDS (Relational Database Service)

It is a cloud database service supporting multiple engines like MySQL, PostgreSQL, and SQL Server.

Use case: Fintech companies use Amazon RDS to manage customer accounts and transactions securely in the cloud.

Also Read: Top 10 Data Modeling Tools You Must Know

With an understanding of various database management tools for efficient data handling, let’s explore techniques to enhance database performance.

How to Improve Database Performance? Key Techniques and Methods

Techniques like indexing, normalization, and query optimization help reduce execution time while ensuring data consistency and integrity.

Here are some techniques that can improve the performance of database systems.

  • Indexing 

Indexing creates a data structure that enables faster searches by reducing the number of records scanned. Instead of a full table scan, the database locates the required data using indexed columns, significantly boosting read performance.

Example: In e-commerce, indexing the product_name column helps retrieve product search results faster, ensuring customers get instant suggestions when typing.

  • Query Optimization

Query optimizing involves restructuring them to reduce execution time. Using efficient joins, it reduces sub-queries, reducing execution time.

Example: In banking, rewriting a complex loan approval query with proper joins and indexing reduces processing time, enabling faster decision-making.

  • Normalization

Normalization organizes data into structured tables, minimizing redundancy and improving consistency. This reduces storage requirements and prevents anomalies during data operations. 

Example: In healthcare, normalizing patient records into separate tables (patient details, diagnoses, and treatments) reduces data duplication and ensures efficient updates.

  • Denormalization

It adds some redundancy to reduce the need for complex joins. This redundancy speeds up data retrieval for frequently accessed records.

Example: In content streaming platforms, denormalizing user watch history allows faster recommendations without excessive joins.

  • Partitioning

Partitioning splits large datasets into smaller, manageable chunks based on certain criteria. This reduces the amount of data scanned per query, improving speed.

Example: In telecommunications, call records are partitioned by month to allow quick retrieval of recent customer interactions without scanning old data.

  • Caching 

Caching stores query results or frequently used data in memory or temporary storage. This reduces repeated database queries and decreases response times.

Example: In social media, caching user profile data ensures fast profile loads, reducing unnecessary database queries when users repeatedly access the same page.

  • Load Balancing

Load balancing prevents server overload by distributing database queries across multiple servers. This ensures consistent performance even during high-traffic periods.

Example: In online gaming, load balancing ensures millions of players can access game servers without delays or crashes.

  • Connection Pooling 

It reuses existing database connections instead of opening and closing new ones. This reduces latency and resource consumption.

Example: In fintech applications, connection pooling speeds up authentication requests for millions of users logging in simultaneously.

  • Concurrency Control

Concurrency control uses mechanisms like locking and timestamp ordering to ensure data consistency. This prevents conflicts and data loss when multiple users attempt to modify the same record. 

Example: In airline reservation systems, concurrency control ensures that two customers do not book the same seat simultaneously, avoiding duplicate reservations. 

Now that you’ve explored techniques to enhance DBMS performance, let’s examine its advantages, challenges, and applications.

What are the Advantages, Limitations and Applications of DBMS?

DBMS provides advantages such as efficient data organization and integrity, but it also faces challenges like high costs and complex data management. Despite these issues, it is widely used in industries like finance for secure data storage and airlines for managing reservations.

Here’s a breakdown of its advantages, challenges, and applications.

Advantages of DBMS

Advantages of DBMS include efficient data storage, maintaining data integrity, and ensuring security against unauthorized access.

Here are the different advantages of DBMS.

  • Data Organization

DBMS organizes structured data efficiently, allowing quick retrieval and secure updates. 

Example: In healthcare, patient records are categorized based on demographics, medical history, and treatment plans, allowing doctors to retrieve specific details quickly for accurate diagnosis.

  • Data Integrity

It ensures data accuracy and consistency by implementing rules like unique constraints, foreign keys, and validation checks, preventing errors and duplication.

Example: In banking, DBMS maintains accurate customer details by ensuring that account numbers are unique and that transactions follow the predefined validation rules, avoiding discrepancies.

Also Read: Integrity Constraints in DBMS: Purpose, Types, Challenges, and Best Practices to Know in 2025

  • Concurrent Access

Allows multiple users to access and modify data simultaneously without conflicts, ensuring smooth operations in multi-user environments.

Example: In e-commerce, DBMS enables thousands of customers to browse products, add items to carts, and complete purchases at the same time without interfering with each other’s transactions.

  • Data Security

Implements access control mechanisms and authentication protocols to protect sensitive information from unauthorized access.

Example: In government databases, DBMS restricts access to confidential citizen records, ensuring that only authorized personnel can view or modify the data.

  • Backup and Recovery

Data is periodically saved and can be restored in case of accidental deletion, hardware failures, or cyberattacks, minimizing data loss.

Example: In finance, banks use DBMS to create regular backups of transaction logs and customer records, ensuring seamless recovery after technical failures.

Let’s check out the limitations of database management systems.

Limitations of DBMS

Limitations of DBMS include complex implementation, high maintenance costs, and scalability challenges, which impact data storage and retrieval efficiency.

Here are the limitations of DBMS.

  • Complexity

DBMS needs careful setup, configuration, and ongoing management, making it challenging for businesses without technical expertise.

Example: In healthcare, setting up an electronic medical records (EMR) system requires complex schema design, security configurations, and compliance measures.

  • Performance Overhead

As databases expand, query execution and transaction processing can slow down due to indexing, logging, and concurrency controls.

Example: In banking, real-time fraud detection queries on massive transaction data can lead to performance lags, requiring optimization strategies like caching and indexing.

  • Scalability

Expanding a DBMS to handle high traffic and large datasets needs additional hardware, sharding, or distributed architectures.

Example: In e-commerce, handling flash sales with millions of concurrent users may need scaling databases horizontally, which can be costly.

  • Cost

Licensing fees, hardware, maintenance, and skilled personnel can increase operational costs, making DBMS adoption expensive for small businesses.

Example: In finance, deploying enterprise-grade DBMS like Oracle or IBM DB2 for secure transaction management needs significant investment in infrastructure and database administrators.

  • Limited Use Cases

Modern RDBMS like PostgreSQL and MySQL now support semi-structured data with JSON, XML, and BLOB storage, reducing reliance on NoSQL for such use cases.

Example: In social media, platforms dealing with vast amounts of user-generated multimedia content often prefer NoSQL databases like MongoDB over traditional RDBM.

Also Read: 15 Disadvantages of DBMS (Database Management System)

Despite its limitations, DBMS remains essential in industries like finance and healthcare, ensuring efficient and secure data management. Let’s explore its applications.

Real-World Applications of DBMS

DBMS is widely used in sectors like finance and banking for managing customer records, healthcare for storing patient data, and airlines for handling reservations efficiently.

Here are its real-world applications.

Industry  Application 
Enterprise Information

To manage employee records, internal documentation, and business intelligence data for efficient decision-making.

Example: HR systems use DBMS to store employee payroll, performance reviews, and attendance records.

Banking and Finance sector

For secure transaction processing, fraud detection, and regulatory compliance in financial institutions.

Example: Banks use DBMS to track account balances, process fund transfers, and ensure real-time fraud detection.

Education

Storing student records, managing admissions, and tracking academic progress.

Example: Colleges use DBMS to maintain course enrollments, student grades, and faculty schedules, 

Airlines 

Handling flight reservations, passenger details, and ticketing systems, ensuring efficient operations.

Example: Airlines manage real-time seat availability, track flight schedules, and handle customer loyalty using DBMS.

Telecommunications

DBMS handles customer subscriptions, call records, and billing systems for telecom providers.

Example: Companies use DBMS to track customer call logs, manage billing, and optimize network usage.

With an understanding of DBMS applications in industries like finance and telecommunications, let’s explore ways to deepen your knowledge in this field.

How Can upGrad Help You Advance Your Career?

Database management systems play a crucial role in storing, manipulating, and analyzing data, making them essential for industries like finance and e-commerce. With DBMS expertise, you can explore roles such as database administrator and database architect. 

However, strong technical skills are necessary for effective database management. upGrad’s industry-focused courses provide foundational knowledge, hands-on experience, and industry insights to help you build a career or transition into higher roles.

Here are some courses offered by upGrad for upskilling.

Not sure which course is right for you? Book a free one-on-one career counseling with upGrad to shape your career, or visit your nearest upGrad center and start hands-on training today!

Unlock the power of data with our popular Data Science courses, designed to make you proficient in analytics, machine learning, and big data!

Elevate your career by learning essential Data Science skills such as statistical modeling, big data processing, predictive analytics, and SQL!

Stay informed and inspired with our popular Data Science articles, offering expert insights, trends, and practical tips for aspiring data professionals!

References:
https://www.verifiedmarketresearch.com/product/database-management-system-dbms-market/

Frequently Asked Questions (FAQs)

1. What is the purpose of a database management system?

A Database Management System (DBMS) stores, manages, and retrieves data efficiently while ensuring data integrity and security.

2. Explain the different types of database management systems.

The four types of database management systems are Relational DBMS (RDBMS), NoSQL DBMS, Distributed DBMS, Cloud-native databases, and Object-oriented DBMS.

3. What are the four major components of a database management system?

The four major components of a database management system are hardware, software, data, and users.

4. What is a key in a database management system?

A key is an attribute or set of attributes that identifies a certain record in a table, such as Primary Key, Foreign Key, and Candidate Key.

5. What is an ER diagram in a database management system?

An Entity-Relationship (ER) diagram is a graphical representation of entities, attributes, and relationships in a database.

6. What is normalization in a database management system?

Normalization is the process of organizing data to reduce redundancy and improve data integrity by dividing large tables into smaller, related ones.

7. What are the best database management system tools?

Some popular database management systems include PostgreSQL, MySQL, Oracle DB, Microsoft SQL Server, and MongoDB.

8. What are MDM tools?

Master Data Management (MDM) tools help maintain consistent, accurate, and unified data across an organization. Examples include Informatica MDM, SAP MDM, and IBM InfoSphere.

9. What are the five factors of database performance?

The five key factors of database performance are query optimization, indexing, hardware resources, database design, and concurrency control.

10. What are the main limitations of a database management system?

The main limitations of a database management system include high cost, complex implementation, performance issues with large datasets, and security vulnerabilities.

11. What is error handling in a database management system?

Error handling refers to mechanisms to detect, log, and manage errors like constraint violations, syntax errors, and transaction failures.

Rohit Sharma

834 articles published

Rohit Sharma is the Head of Revenue & Programs (International), with over 8 years of experience in business analytics, EdTech, and program management. He holds an M.Tech from IIT Delhi and specializes...

Speak with Data Science Expert

+91

By submitting, I accept the T&C and
Privacy Policy

Start Your Career in Data Science Today

Top Resources

Recommended Programs

IIIT Bangalore logo
bestseller

The International Institute of Information Technology, Bangalore

Executive Diploma in DS & AI

360° Career Support

Executive PG Program

12 Months

Liverpool John Moores University Logo
bestseller

Liverpool John Moores University

MS in Data Science

Double Credentials

Master's Degree

17 Months

upGrad Logo

Certification

3 Months