Java MySQL – SELECT DISTINCT
In this tutorial, you will learn how to use the SELECT DISTINCT
statement in MySQL with Java to retrieve unique records from a table. We’ll cover connecting Java to MySQL, writing Java code to execute the SELECT DISTINCT
query, and verifying the output.
This tutorial includes examples of selecting distinct values from a single column and multiple columns.
Prerequisites
- MySQL installed and running
- Java Development Kit (JDK) installed
- MySQL Connector/J (JDBC Driver) downloaded
- MySQL Workbench to verify the query results
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');
INSERT INTO students (name, age, class) VALUES ('Alice', 19, '10A'); -- Duplicate entry for testing DISTINCT
This setup creates the school
database and a students
table with sample data, including duplicate entries for testing the SELECT DISTINCT
query.
data:image/s3,"s3://crabby-images/d62a6/d62a6ec5961a676376cbcdc74da14f4f3016eac7" alt=""
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 Use SELECT DISTINCT
Let’s go through examples of using the SELECT DISTINCT
statement in Java to retrieve unique records from the students
table.
data:image/s3,"s3://crabby-images/eff72/eff7229a5bb9fa207a0a6a1b71afcebbfa8d07bb" alt=""
Example 1: Select Distinct Values from a Single Column
This example retrieves distinct values from the name
column in the students
table.
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
public class SelectDistinctExample {
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 select distinct names
String sql = "SELECT DISTINCT name FROM students";
// Create a statement and execute the query
Statement statement = connection.createStatement();
ResultSet resultSet = statement.executeQuery(sql);
// Process the result set
System.out.println("Distinct Names:");
while (resultSet.next()) {
String name = resultSet.getString("name");
System.out.println(name);
}
// Close resources
resultSet.close();
statement.close();
connection.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
This code retrieves distinct names from the students
table. If there are duplicate names, only unique names will be displayed.
data:image/s3,"s3://crabby-images/df92b/df92bb80dbc844827bce0a9f458bc1562d7155c2" alt="Select Distinct Values from a Single Column - Eclipse Java JDBC Output"
After running the Java program, open MySQL Workbench and execute the following query to verify the results:
SELECT DISTINCT name FROM students;
data:image/s3,"s3://crabby-images/f062e/f062e6a1fb2679d31796fdbdbb33309f33e460a3" alt="Select Distinct Values from a Single Column - MySQL Workbench Verification"
Example 2: Select Distinct Values from Multiple Columns
This example retrieves distinct combinations of name
and class
from the students
table.
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
public class SelectDistinctMultipleColumnsExample {
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 select distinct name and class
String sql = "SELECT DISTINCT name, class FROM students";
// Create a statement and execute the query
Statement statement = connection.createStatement();
ResultSet resultSet = statement.executeQuery(sql);
// Process the result set
System.out.println("Distinct Name and Class:");
while (resultSet.next()) {
String name = resultSet.getString("name");
String studentClass = resultSet.getString("class");
System.out.println("Name: " + name + ", Class: " + studentClass);
}
// Close resources
resultSet.close();
statement.close();
connection.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
This code retrieves distinct combinations of name
and class
, ensuring that only unique pairs are displayed.
data:image/s3,"s3://crabby-images/12245/1224524a418b7535e819a4e2a577a87e0c9543f6" alt=""
After running the Java program, open MySQL Workbench and execute the following query to verify the results:
SELECT DISTINCT name, class FROM students;
data:image/s3,"s3://crabby-images/72bf8/72bf89e09e291b2d263ec23266836d165a23de9d" alt="Select Distinct Values from Multiple Columns - MySQL Workbench Verification"
Example 3: Using DISTINCT with a WHERE Clause
This example retrieves distinct class
values where the age is greater than 20.
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
public class SelectDistinctWithWhereExample {
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 select distinct classes where age > 20
String sql = "SELECT DISTINCT class FROM students WHERE age > 20";
// Create a statement and execute the query
Statement statement = connection.createStatement();
ResultSet resultSet = statement.executeQuery(sql);
// Process the result set
System.out.println("Distinct Classes (Age > 20):");
while (resultSet.next()) {
String studentClass = resultSet.getString("class");
System.out.println(studentClass);
}
// Close resources
resultSet.close();
statement.close();
connection.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
This code retrieves distinct class
values where the age of the student is greater than 20.
data:image/s3,"s3://crabby-images/9640d/9640dd061a9f1ee69b33eafb1bccb0e1d84229c1" alt=""
After running the Java program, open MySQL Workbench and execute the following query to verify the results:
SELECT DISTINCT class FROM students WHERE age > 20;
data:image/s3,"s3://crabby-images/ef552/ef5526c48c7594e1ad5f6a0d3c6931b1095bd859" alt="Using DISTINCT with a WHERE Clause - MySQL Workbench Verification"
Conclusion
Using SELECT DISTINCT
in MySQL with Java is a powerful way to retrieve unique records from a table. This tutorial provided examples of selecting distinct values from a single column, multiple columns, and using conditions. These techniques can be applied to various scenarios in your Java applications to ensure data uniqueness.