Me: give dbms complete ans
PDF: Here are the complete answers to the Database Management Systems (DBMS)
questions as outlined in the document:
1. **Explain normalization and why it is important. Describe 1NF, 2NF, and 3NF.**
   - **Normalization** is the process of organizing data in a database to reduce
redundancy and improve data integrity. It involves dividing large tables into
smaller ones and defining relationships between them.
     - **1NF (First Normal Form)**: A table is in 1NF if it contains only atomic
(indivisible) values and each entry in a column is of the same data type. There
should be no repeating groups or arrays.
     - **2NF (Second Normal Form)**: A table is in 2NF if it is in 1NF and all non-
key attributes are fully functionally dependent on the primary key. This means that
no partial dependency of any column on the primary key should exist.
     - **3NF (Third Normal Form)**: A table is in 3NF if it is in 2NF and all the
attributes are functionally dependent only on the primary key. There should be no
transitive dependency, meaning non-key attributes should not depend on other non-
key attributes.
2. **What are primary keys and foreign keys? Provide examples.**
   - **Primary Key**: A primary key is a unique identifier for a record in a table.
It cannot contain NULL values and must contain unique values. For example, in a
table of employees, the employee ID can serve as a primary key.
   - **Foreign Key**: A foreign key is a field (or collection of fields) in one
table that uniquely identifies a row of another table. It establishes a
relationship between the two tables. For example, in an orders table, the employee
ID can be a foreign key that references the employee ID in the employees table.
3. **Write an SQL query to find the second-highest salary from a table.**
   ```sql
   SELECT MAX(salary) AS SecondHighestSalary
   FROM employees
   WHERE salary < (SELECT MAX(salary) FROM employees);
   ```
4. **Explain the difference between DELETE, TRUNCATE, and DROP commands.**
   - **DELETE**: This command is used to remove specific rows from a table based on
a condition. It can be rolled back if used within a transaction.
   - **TRUNCATE**: This command removes all rows from a table without logging
individual row deletions. It cannot be rolled back and resets any auto-increment
counters.
   - **DROP**: This command removes a table (or database) entirely from the
database. All data, structure, and permissions are lost, and it cannot be rolled
back.
5. **What are indexes? How do they improve query performance?**
   - **Indexes** are special data structures that improve the speed of data
retrieval operations on a database table. They work like a book's index, allowing
the database to find data without scanning the entire table. Indexes can
significantly reduce the time it takes to execute queries, especially on large
datasets.
6. **What are joins in SQL? Explain INNER JOIN and LEFT JOIN with examples.**
   - **Joins** are used to combine rows from two or more tables based on a related
column between them.
     - **INNER JOIN**: Returns records that have matching values in both tables.
       ```sql
       SELECT employees.name, departments.department_name
       FROM employees
       INNER JOIN departments ON employees.department_id = departments.id;
       ```
     - **LEFT JOIN**: Returns all records from the left table and the matched
records from the right table. If there is no match, NULL values are returned for
columns from the right table.
       ```sql
       SELECT employees.name, departments.department_name
       FROM employees
       LEFT JOIN departments ON employees.department_id = departments.id;
       ```
7. **What is ACID in databases? How is it implemented?**
   - **ACID** stands for Atomicity, Consistency, Isolation, and Durability. These
properties ensure reliable processing of database transactions.
     - **Atomicity**: Ensures that all operations within a transaction are
completed successfully; if not, the transaction is aborted.
     - **Consistency**: Ensures that a transaction brings the database from one
valid state to another, maintaining all predefined rules.
     - **Isolation**: Ensures that transactions are executed in isolation from one
another, preventing concurrent transactions from affecting each other.
     - **Durability**: Ensures that once a transaction is committed, it remains so,
even in the event of a system failure.
   - ACID is implemented through transaction management systems in database
management systems.
8. **How do you handle duplicate rows in SQL?**
   - Duplicate rows can be handled using the `DISTINCT` keyword in a SELECT
statement to return only unique rows. Alternatively, you can use the `GROUP BY`
clause to group rows based on specific columns.
   ```sql
   SELECT DISTINCT column1, column2 FROM table_name;
   ```
9. **Explain the difference between SQL and NoSQL databases with examples.**
   - **SQL Databases**: These are relational databases that use structured query
language (SQL) for defining and manipulating data. They are table-based and enforce
a schema. Examples include MySQL, PostgreSQL, and Oracle.
   - **NoSQL Databases**: These are non-relational databases that can store
unstructured or semi-structured data. They are more flexible and can handle large
volumes of data. Examples include MongoDB, Cassandra, and Redis.
10. **What is a stored procedure? When would you use it?**
    - A **stored procedure** is a precompiled collection of one or more SQL
statements that can be executed as a single unit. Stored procedures are used to
encapsulate complex business logic, improve performance by reducing network
traffic, and enhance security by controlling access to data.
11. **Write an SQL query to find all employees with salaries above the average.**
    ```sql
    SELECT * FROM employees
    WHERE salary > (SELECT AVG(salary) FROM employees);
    ```
12. **What is the difference between UNION and UNION ALL?**
    - **UNION**: Combines the result sets of two or more SELECT statements and
removes duplicate rows from the result.
    - **UNION ALL**: Combines the result sets of two or more SELECT statements but
includes all duplicates.
    ```sql
    SELECT column_name FROM table1
    UNION
    SELECT column_name FROM table2;
    SELECT column_name FROM table1
    UNION ALL
    SELECT column_name FROM table2;
    ```
13. **What are views in SQL? How are they useful?**
    - A **view** is a virtual table based on the result of a SELECT query. It does
not store data physically but provides a way to simplify complex queries, enhance
security by restricting access to specific data, and present data in a specific
format.
14. **Explain the concept of database transactions and rollback.**
    - A **database transaction** is a sequence of operations performed as a single
logical unit of work. Transactions ensure data integrity and consistency. If any
operation within the transaction fails, the entire transaction can be rolled back
to maintain the database's previous state.
15. **What is denormalization, and when is it preferred?**
    - **Denormalization** is the process of intentionally introducing redundancy
into a database by merging tables or adding redundant data. It is preferred in
scenarios where read performance is critical, and complex joins can be avoided,
such as in data warehousing or reporting systems.
These answers provide a comprehensive overview of the key concepts in Database
Management Systems.