MySQL Interview Questions for Developers

author image Hirely
at 07 Jan, 2025

Question: How does MySQL handle transactions?

Answer:

MySQL handles transactions using the ACID properties, ensuring that database operations are reliable, consistent, and recoverable. A transaction in MySQL is a sequence of one or more SQL operations that are executed as a single unit of work. If any of the operations fail, the entire transaction can be rolled back to maintain data integrity.

ACID Properties:

MySQL uses the ACID p** roperties to manage transactions:

  1. Atomicity: Ensures that a transaction is treated as a single unit, meaning either all of its operations are completed successfully, or none of them are applied (rolled back). If an error occurs, the transaction is rolled back, and the database remains unchanged.

  2. Consistency: Guarantees that a transaction brings the database from one valid state to another. If the transaction is successful, all constraints and rules (like foreign keys and checks) are preserved.

  3. Isolation: Ensures that the operations of one transaction are isolated from others. The changes made by a transaction are not visible to other transactions until the transaction is committed. MySQL offers different isolation levels to control how transactions interact with each other.

  4. Durability: Once a transaction is committed, its changes are permanent, even in the event of a system failure. The changes are saved to disk, ensuring data persistence.

Transaction Handling in MySQL:

To work with transactions in MySQL, you can use the following commands:

  1. START TRANSACTION (or BEGIN):

    • This command is used to begin a new transaction.
    • Once a transaction is started, all subsequent SQL statements are part of that transaction until it is either committed or rolled back.
    START TRANSACTION;
  2. COMMIT:

    • This command is used to save all changes made during the transaction. After committing a transaction, all changes become permanent.
    COMMIT;
  3. ROLLBACK:

    • If an error occurs or you want to undo the changes made during the transaction, you can use ROLLBACK to revert the database to the state it was in before the transaction began.
    ROLLBACK;
  4. SAVEPOINT:

    • This command is used to create a savepoint within a transaction. A savepoint is a point in the transaction to which you can roll back later without affecting the entire transaction.
    SAVEPOINT savepoint_name;
  5. RELEASE SAVEPOINT:

    • This command removes a previously defined savepoint.
    RELEASE SAVEPOINT savepoint_name;
  6. SET AUTOCOMMIT:

    • In MySQL, you can control the autocommit mode. When autocommit is enabled, each SQL statement is treated as a transaction by itself.
    • By default, autocommit is enabled in MySQL, meaning each statement is automatically committed.
    • You can disable autocommit to handle multiple statements as a single transaction.
    SET AUTOCOMMIT = 0; -- Disable autocommit
    SET AUTOCOMMIT = 1; -- Enable autocommit

Isolation Levels in MySQL:

MySQL provides different transaction isolation levels to control the visibility of transactions to each other. The isolation level determines how and when the changes made by one transaction become visible to other concurrent transactions. MySQL supports the following isolation levels:

  1. READ UNCOMMITTED:

    • Transactions can see uncommitted changes made by other transactions.
    • Dirty reads: It allows reading data that might later be rolled back by other transactions.
    • Lowest level of isolation and may lead to inconsistencies in the data.
  2. READ COMMITTED:

    • A transaction can only see committed changes made by other transactions.
    • Non-repeatable reads: Data read during a transaction may change if another transaction commits changes before the transaction completes.
  3. REPEATABLE READ (default in MySQL):

    • Ensures that if a transaction reads a row, the value of that row will not change throughout the duration of the transaction, even if other transactions modify it.
    • Phantom reads: New rows inserted by other transactions could be seen if the transaction re-executes a query.
    • This is the default isolation level in MySQL and is usually sufficient for most applications.
  4. SERIALIZABLE:

    • The highest isolation level.
    • It ensures that no other transactions can access the data being read by the current transaction. It serializes access to data, effectively making transactions execute sequentially.
    • Prevents phantom reads, but can lead to performance degradation due to blocking of other transactions.

Syntax for Setting Isolation Levels:

-- Set isolation level for a transaction
SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;

Transaction Example:

Let’s say you are transferring money between two accounts. Here’s how a transaction might work:

  1. Start a transaction:

    START TRANSACTION;
  2. Debit from Account 1:

    UPDATE accounts SET balance = balance - 100 WHERE account_id = 1;
  3. Credit to Account 2:

    UPDATE accounts SET balance = balance + 100 WHERE account_id = 2;
  4. Commit the transaction:

    COMMIT;

If any error occurs during the process, such as insufficient funds, you can rollback the transaction:

ROLLBACK;

Handling Concurrency with Transactions:

MySQL provides transaction isolation levels that help manage how transactions interact with each other, especially in high-concurrency environments. These levels control the visibility of uncommitted data between transactions, ensuring data consistency while avoiding conflicts like dirty reads, non-repeatable reads, and phantom reads.

Example: Different Isolation Levels

  1. READ UNCOMMITTED (Dirty Reads):

    • Transaction 1 modifies a row, and Transaction 2 can read the uncommitted data.
  2. READ COMMITTED (Non-Repeatable Reads):

    • Transaction 1 reads a row, and Transaction 2 commits changes to that row, causing inconsistent results if Transaction 1 reads the row again.
  3. REPEATABLE READ (Phantom Reads):

    • Transaction 1 reads a set of rows. Transaction 2 inserts new rows, and Transaction 1 reads the set again, but with new rows included.
  4. SERIALIZABLE (No Concurrency):

    • Transactions are executed one after the other, preventing any conflicts but reducing concurrency and performance.

Summary:

  • MySQL handles transactions using the ACID properties (Atomicity, Consistency, Isolation, Durability) to ensure data integrity and reliability.
  • Transactions in MySQL are managed with commands like START TRANSACTION, COMMIT, and ROLLBACK.
  • Isolation levels control the visibility of uncommitted changes across concurrent transactions and help manage concurrency issues like dirty reads, non-repeatable reads, and phantom reads.
  • MySQL provides a default isolation level of REPEATABLE READ, but you can adjust this based on the requirements of your application.

Question: Explain the AUTO_INCREMENT feature in MySQL.

Answer:

The AUTO_INCREMENT feature in MySQL is used to automatically generate a unique, sequential value for a column whenever a new record is inserted into a table. This feature is commonly used for primary key columns to ensure that each new row gets a unique identifier without needing the user to manually assign a value. Typically, the AUTO_INCREMENT column is set as the primary key of the table.

Key Features of AUTO_INCREMENT:

  1. Automatic Generation of Unique Values:

    • When you insert a row into the table without specifying a value for the AUTO_INCREMENT column, MySQL automatically assigns the next available integer value to that column.
  2. Sequential Values:

    • The values assigned to an AUTO_INCREMENT column are sequential. By default, the sequence starts at 1 and increments by 1 for each new row.
    • The value is unique for each row, ensuring no duplicates in the AUTO_INCREMENT column.
  3. No Need to Manually Specify Values:

    • When inserting data, you do not need to specify a value for the AUTO_INCREMENT column. MySQL will take care of it.
    • Example: INSERT INTO table_name (column2, column3) VALUES ('value2', 'value3');—the AUTO_INCREMENT column will be filled automatically.
  4. Customizing the Starting Value:

    • You can customize the starting point of the AUTO_INCREMENT sequence by specifying a value when creating the table or by altering the table afterward.
    • The default starting value is 1, but you can set it to another number if needed.
  5. Handling Gaps:

    • Gaps in the sequence of AUTO_INCREMENT values may occur if a row is deleted, or if a transaction fails after generating an AUTO_INCREMENT value but before inserting the row. However, MySQL will not reuse these gaps.
    • The next AUTO_INCREMENT value will be the next sequential integer, and the gap will remain.
  6. AUTO_INCREMENT and Primary Keys:

    • The AUTO_INCREMENT feature is typically used for columns that are defined as primary keys. The value generated by AUTO_INCREMENT ensures that the primary key column has unique values for each row.
  7. Limits:

    • The maximum value for an AUTO_INCREMENT column depends on the data type of the column. For example:
      • INT can hold values from 1 to 2,147,483,647 (signed) or 0 to 4,294,967,295 (unsigned).
      • BIGINT can hold much larger values, from -9,223,372,036,854,775,808 to 9,223,372,036,854,775,807 (signed).
      • TINYINT, SMALLINT, MEDIUMINT, etc., have respective maximum values based on their size.
  8. Resetting the AUTO_INCREMENT Value:

    • You can reset the AUTO_INCREMENT counter for a table, typically after truncating the table or deleting all rows.
    • Example:
      ALTER TABLE table_name AUTO_INCREMENT = 1;
      This resets the next AUTO_INCREMENT value to 1 (or another specified value).

Syntax for Using AUTO_INCREMENT:

  1. Creating a Table with an AUTO_INCREMENT Column:

    CREATE TABLE users (
      user_id INT AUTO_INCREMENT,
      username VARCHAR(100),
      email VARCHAR(100),
      PRIMARY KEY (user_id)
    );
    • In this example, the user_id column is an AUTO_INCREMENT column. When a new record is inserted into the users table, MySQL will automatically assign a unique, sequential value to the user_id column.
  2. Inserting Data Without Specifying the AUTO_INCREMENT Value:

    INSERT INTO users (username, email) VALUES ('john_doe', '[email protected]');
    • You do not need to specify a value for user_id. MySQL will automatically assign the next available value.
  3. Specifying the Next Value for AUTO_INCREMENT:

    ALTER TABLE users AUTO_INCREMENT = 1001;
    • This command sets the next AUTO_INCREMENT value for the users table to 1001.
  4. Retrieving the Last Inserted AUTO_INCREMENT Value:

    • You can use the LAST_INSERT_ID() function to retrieve the last automatically generated value for an AUTO_INCREMENT column.
    SELECT LAST_INSERT_ID();

Example Usage:

Step 1: Creating the Table

CREATE TABLE products (
  product_id INT AUTO_INCREMENT,
  product_name VARCHAR(100),
  price DECIMAL(10, 2),
  PRIMARY KEY (product_id)
);

In this example, product_id is an AUTO_INCREMENT column, meaning each time you insert a new row, MySQL will automatically generate a unique value for product_id.

Step 2: Inserting Data Without Specifying product_id

INSERT INTO products (product_name, price) VALUES ('Laptop', 999.99);
INSERT INTO products (product_name, price) VALUES ('Smartphone', 699.99);
  • After the first insertion, product_id will automatically be 1, and after the second insertion, it will automatically be 2, without the need for manual intervention.

Step 3: Checking the product_id

SELECT * FROM products;

Output:

+------------+----------------+-------+
| product_id | product_name   | price |
+------------+----------------+-------+
| 1          | Laptop         | 999.99|
| 2          | Smartphone     | 699.99|
+------------+----------------+-------+

Step 4: Resetting the AUTO_INCREMENT Value

ALTER TABLE products AUTO_INCREMENT = 1;
  • This command will reset the AUTO_INCREMENT value to 1, meaning the next insertion will assign product_id = 1 (if no rows exist).

Common Use Cases for AUTO_INCREMENT:

  1. Primary Key Generation: Most commonly used to generate unique IDs for rows, especially when those IDs are used as primary keys in relational tables.
  2. Seamless Record Insertion: Simplifies record insertion, as there’s no need to manually specify a unique value for each row.
  3. Tracking Sequential Data: Useful for scenarios where you need to keep track of records in a specific order, like invoice numbers, order IDs, etc.

Summary:

  • The AUTO_INCREMENT feature in MySQL automatically generates unique, sequential values for a column whenever a new record is inserted.
  • It is typically used for primary key columns to ensure each row has a unique identifier.
  • You can customize the starting value and reset the counter if needed.
  • It simplifies data insertion by eliminating the need to manually assign unique values to certain columns.

Read More

If you can’t get enough from this article, Aihirely has plenty more related information, such as MySQL interview questions, MySQL interview experiences, and details about various MySQL job positions. Click here to check it out.

Related Posts

Trace Job opportunities

Hirely, your exclusive interview companion, empowers your competence and facilitates your interviews.

Get Started Now