Java MySQL – DELETE Row(s)
This tutorial explains how to delete rows in a MySQL table using Java. We will go through different scenarios, including deleting a single row, deleting multiple rows based on a condition, and deleting all rows in a table. Each example includes detailed steps and Java code snippets.
Prerequisites
- MySQL installed and running
- Java Development Kit (JDK) installed
- MySQL Connector/J (JDBC Driver) downloaded
- MySQL Workbench to verify the row deletions
Step 1: Set Up MySQL Database and Table
Before running the Java code, create a sample table in MySQL. We’ll use a table named students
with columns for ID, name, age, and class. Run the following SQL commands in MySQL Workbench:
CREATE DATABASE IF NOT EXISTS school;
USE school;
CREATE TABLE IF NOT EXISTS students (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(50),
age INT,
class VARCHAR(10)
);
-- Insert sample data
INSERT INTO students (name, age, class) VALUES ('Alice', 19, '10A');
INSERT INTO students (name, age, class) VALUES ('Bob', 20, '10B');
INSERT INTO students (name, age, class) VALUES ('Charlie', 21, '10A');
INSERT INTO students (name, age, class) VALUES ('Daisy', 22, '10B');
This setup creates the school
database and a students
table with sample data to use in our examples.
data:image/s3,"s3://crabby-images/81de5/81de5ed34e6f8aedf48bbc638bcfec0e05e1ab16" alt="Java MySQL - DELETE Row(s) - Sample Table Data"
Step 2: Set Up MySQL Connection in Java
To connect to MySQL from Java, you need the MySQL Connector/J library. Add this library to your Java project to establish the connection.
1. Download MySQL Connector/J
Go to the official MySQL Connector/J download page, download the connector, and add the JAR file to your Java project’s classpath.
data:image/s3,"s3://crabby-images/cd8bc/cd8bc7b92b904e02dbd15a66b6707a8481a9ed0d" alt="Download MySQL Connector/J"
data:image/s3,"s3://crabby-images/0e78c/0e78c312bfa172960d41766734d3ef15edb7d4cd" alt="Download MySQL Connector/J Zip Download"
Click on the Download button.
data:image/s3,"s3://crabby-images/ea663/ea663e225ac9715edb29711cce288cb3aaa77987" alt="Download MySQL Connector/J - Start Download"
You may click No thanks, just start my download.
In the downloaded package, there should be a jar file.
data:image/s3,"s3://crabby-images/f0e25/f0e254529e65fb26a7ac4ae99c88ac3d5e4e2ceb" alt="MySQL Connector/J Jar File"
2. Add the Connector to Your Java Project
For the sake of convenience, let us copy the jar file to libs folder in the Java Project.
data:image/s3,"s3://crabby-images/ef8d8/ef8d8e793b2d457529865622eb4f8279a84b5216" alt="Add the MySQL Connector to Your Java Project"
Right-click on your Java project and go to Properties.
Select Java Build Path > Libraries.
data:image/s3,"s3://crabby-images/a446f/a446fa3f577a6d16e8abef7dfe301b479dfba427" alt="Add MySQL Connector/J JAR file to Java Build Path"
Add the MySQL Connector/J JAR file you downloaded.
data:image/s3,"s3://crabby-images/85153/85153a6ea2dfaec9bf0691e7912636eb5756aa4f" alt="Add MySQL Connector/J JAR file to Java Build Path - JAR Selection"
Click OK.
data:image/s3,"s3://crabby-images/8322e/8322e2f24dc58972686ab7df868b41a2d95dd51b" alt="Add MySQL Connector/J JAR file to Java Build Path - Apply and Close"
Click Apply and Close.
Step 3: Java Code to DELETE Rows
We will now explore different examples for deleting rows from the students
table in MySQL.
data:image/s3,"s3://crabby-images/95d73/95d7363cdd3bde71598490e70f8c6dd692c23db1" alt="Java MySQL - DELETE Rows - Sample Table Data"
Example 1: Delete a Single Row
This example demonstrates deleting a specific row based on the id
of the student.
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
public class DeleteSingleRowExample {
public static void main(String[] args) {
String jdbcUrl = "jdbc:mysql://localhost:3306/school";
String user = "root";
String password = "your_password";
try {
// Establish a connection to MySQL
Connection connection = DriverManager.getConnection(jdbcUrl, user, password);
// SQL command to delete a single row
String sql = "DELETE FROM students WHERE id = ?";
// Prepare the statement
PreparedStatement preparedStatement = connection.prepareStatement(sql);
preparedStatement.setInt(1, 1); // ID of the student to delete (e.g., Alice with id 1)
// Execute the delete command
int rowsDeleted = preparedStatement.executeUpdate();
// Output the result
if (rowsDeleted > 0) {
System.out.println("A row was deleted successfully.");
}
// Close resources
preparedStatement.close();
connection.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
This code deletes the row for the student with id = 1
(e.g., Alice).
data:image/s3,"s3://crabby-images/21a0f/21a0ffbf2a39a7582381f7f124d8ed26492c1260" alt="Java MySQL - Delete Single Row - Java Program Run in Eclipse"
After running the Java program, open MySQL Workbench and run the following query to verify the deletions:
SELECT * FROM students;
data:image/s3,"s3://crabby-images/e5b1a/e5b1aedef0b9dcfa36ecd3a29b5aff5725a921f4" alt="Java MySQL - Delete Single Row - Check output in MySQL Workbench"
Example 2: Delete Multiple Rows Based on a Condition
In this example, we’ll delete all rows where the class
is 10A
.
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
public class DeleteConditionalRowsExample {
public static void main(String[] args) {
String jdbcUrl = "jdbc:mysql://localhost:3306/school";
String user = "root";
String password = "your_password";
try {
// Establish a connection to MySQL
Connection connection = DriverManager.getConnection(jdbcUrl, user, password);
// SQL command to delete multiple rows
String sql = "DELETE FROM students WHERE class = ?";
// Prepare the statement
PreparedStatement preparedStatement = connection.prepareStatement(sql);
preparedStatement.setString(1, "10A"); // Class condition
// Execute the delete command
int rowsDeleted = preparedStatement.executeUpdate();
// Output the result
System.out.println(rowsDeleted + " rows were deleted successfully.");
// Close resources
preparedStatement.close();
connection.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
This code deletes all rows for students in class 10A
.
data:image/s3,"s3://crabby-images/1cd78/1cd788fca9f41f8c58da24007e0e8b208afd4106" alt="Java MySQL - Delete Multiple Rows Based on a Condition - Java Program Run in Eclipse"
After running the Java program, open MySQL Workbench and run the following query to verify the deletions:
SELECT * FROM students;
data:image/s3,"s3://crabby-images/63c03/63c030dadeef8462200597d459a4575405711716" alt="Java MySQL - Delete Multiple Rows Based on a Condition - MySQL Workbench"
Example 3: Delete All Rows
This example demonstrates how to delete all rows from the students
table. Note: This action cannot be undone, so use caution.
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;
public class DeleteAllRowsExample {
public static void main(String[] args) {
String jdbcUrl = "jdbc:mysql://localhost:3306/school";
String user = "root";
String password = "your_password";
try {
// Establish a connection to MySQL
Connection connection = DriverManager.getConnection(jdbcUrl, user, password);
// SQL command to delete all rows
String sql = "DELETE FROM students";
// Create a statement
Statement statement = connection.createStatement();
// Execute the delete command
int rowsDeleted = statement.executeUpdate(sql);
// Output the result
System.out.println("All rows deleted. Total rows affected: " + rowsDeleted);
// Close resources
statement.close();
connection.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
This code deletes all rows from the students
table, leaving it empty.
data:image/s3,"s3://crabby-images/00ac8/00ac8823e5e446ee7bc6e45e8796f6e0fd1d4b9e" alt="Java MySQL - DELETE All Row(s) - Run in eclipse"
After running the Java program, open MySQL Workbench and run the following query to verify the deletions:
SELECT * FROM students;
data:image/s3,"s3://crabby-images/fb251/fb25178ffc8295acabdf59a423f32b55fc25b13b" alt="Java MySQL - DELETE All Row(s) - MySQL Workbench"
Conclusion
This tutorial covered different ways to delete rows from a MySQL table using Java, including deleting a single row, deleting multiple rows based on a condition, and deleting all rows.